我试图将一个简单的文本文件读入字符串。当然,通常有获取输入流并使用readLine()迭代并将内容读入String的方法。

在过去做了数百次之后,我只是想知道如何用最少的代码行来完成这个任务?java中没有类似String fileContents = XXX.readFile(myFile/*File*/) ..而是像这样简单的东西?

我知道有像Apache Commons IO这样的库可以提供这样的简化,甚至我可以写一个简单的Util类来做这件事。但我想知道的是——这是一个如此频繁的操作,每个人都需要,那么为什么Java不提供这样简单的函数?难道真的没有一个方法可以将文件读入具有默认或指定编码的字符串吗?


当前回答

不要写你自己的util类来做这件事——我建议使用Guava,它充满了各种各样的好处。在这种情况下,你需要Files类(如果你真的只是读取一个文件)或CharStreams来进行更通用的读取。它具有将数据读入字符串列表(readLines)或totally (toString)的方法。

它对二进制数据也有类似的有用方法。然后还有图书馆的其他部分……

我同意在标准库中没有类似的东西是令人恼火的。见鬼,只要能够为FileReader提供一个CharSet,就会让生活变得简单一些……

其他回答

我发现接受的答案实际上并不总是有效,因为\\Z可能出现在文件中。另一个问题是,如果你没有正确的字符集,一大堆意想不到的事情可能会发生,这可能会导致扫描器只读取文件的一部分。

解决方案是使用您确定永远不会在文件中出现的分隔符。然而,这在理论上是不可能的。我们能做的是使用一个在文件中出现的几率很小的分隔符,可以忽略不计:这样的分隔符是一个UUID,它在Java中是原生支持的。

String content = new Scanner(file, "UTF-8")
    .useDelimiter(UUID.randomUUID().toString()).next();

你可以使用apache commons IO..

FileInputStream fisTargetFile = new FileInputStream(new File("test.txt"));

String targetFileStr = IOUtils.toString(fisTargetFile, "UTF-8");

不要写你自己的util类来做这件事——我建议使用Guava,它充满了各种各样的好处。在这种情况下,你需要Files类(如果你真的只是读取一个文件)或CharStreams来进行更通用的读取。它具有将数据读入字符串列表(readLines)或totally (toString)的方法。

它对二进制数据也有类似的有用方法。然后还有图书馆的其他部分……

我同意在标准库中没有类似的东西是令人恼火的。见鬼,只要能够为FileReader提供一个CharSet,就会让生活变得简单一些……

很遗憾,没有。

我同意这样频繁的操作应该比在循环中逐行复制输入更容易实现,但您必须要么编写helper方法,要么使用外部库。

从Java 7 (API描述)开始,你可以做:

新字符集(文件.readAllBytes(Paths.get(filePath),默认文件.UTF_8);

其中filePath是一个字符串,表示您要加载的文件。