协慌网

登录 贡献 社区

如何使用 Java 逐行读取大型文本文件?

我需要使用 Java 逐行读取大约 5-6 GB 的大文本文件。

我该怎么办?

答案

一种常见的模式是使用

try (BufferedReader br = new BufferedReader(new FileReader(file))) {
    String line;
    while ((line = br.readLine()) != null) {
       // process the line.
    }
}

如果假设没有字符编码,则可以更快地读取数据。例如 ASCII-7 但它没有太大区别。您对数据的处理很可能需要更长的时间。

编辑:一种不太常见的模式,可以避免line泄漏的范围。

try(BufferedReader br = new BufferedReader(new FileReader(file))) {
    for(String line; (line = br.readLine()) != null; ) {
        // process the line.
    }
    // line is not visible here.
}

更新:在 Java 8 中你可以做到

try (Stream<String> stream = Files.lines(Paths.get(fileName))) {
        stream.forEach(System.out::println);
}

注意:您必须将 Stream 放在try-with-resource块中以确保在其上调用 #close 方法,否则在 GC 稍后执行它之前,基础文件句柄永远不会关闭。

看看这个博客:

可以指定缓冲区大小,或者可以使用默认大小。对于大多数用途,默认值足够大。

// Open the file
FileInputStream fstream = new FileInputStream("textfile.txt");
BufferedReader br = new BufferedReader(new InputStreamReader(fstream));

String strLine;

//Read File Line By Line
while ((strLine = br.readLine()) != null)   {
  // Print the content on the console
  System.out.println (strLine);
}

//Close the input stream
fstream.close();

一旦退出(2014 年 3 月),您将能够使用流:

try (Stream<String> lines = Files.lines(Paths.get(filename), Charset.defaultCharset())) {
  lines.forEachOrdered(line -> process(line));
}

打印文件中的所有行:

try (Stream<String> lines = Files.lines(file, Charset.defaultCharset())) {
  lines.forEachOrdered(System.out::println);
}