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

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

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


当前回答

你可以使用apache commons IO..

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

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

其他回答

很遗憾,没有。

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

这应该对你有用:

import java.io.IOException;
import java.nio.file.Files;
import java.nio.file.Paths;

public static void main(String[] args) throws IOException {
    String content = new String(Files.readAllBytes(Paths.get("abc.java")));
}

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

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

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

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

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

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

你可以使用apache commons IO..

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

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