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

How can I read a large text file line by line using Java?

提问人:manoj singh 提问时间:5/3/2011 最后编辑:Mahozadmanoj singh 更新时间:9/25/2023 访问量:1455027

问:

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

我怎样才能快速做到这一点?

Java 性能 -IO IO 文本文件

评论

97赞 Patrick Cullen 2/6/2013
@kamaci等。铝。此问题不应标记为重复。“快速阅读最后一行”不是一种替代方法,而“逐行阅读文本文件的最快方法”是否是值得商榷的。做某事的最快方法不一定是普通的方法。此外,下面的答案包括代码,您列出的最相关的替代方案不包括。这个问题很有用。它目前是“java read file line by line”的顶级谷歌搜索结果。最后,它令人反感地到达堆栈溢出并发现每 2 个问题中有 1 个被标记为待处理。
5赞 Serg M Ten 11/15/2016
以下是六种可能实现的速度比较。
5赞 Stijn de Witt 10/3/2017
事件虽然我一直在阅读评论,认为 SO 的关闭政策很糟糕,但 SO 坚持其中。想要不惜一切代价避免冗余的开发人员视角是如此狭隘!顺其自然吧!奶油会上升到顶部,而 sh*t 会自行沉到底部。即使以前可能已经问过一个问题(哪个问题不是??),但这并不意味着一个新问题可能无法更好地表达它,获得更好的答案,在搜索引擎中排名更高等。有趣的是,这个问题现在被“保护”了......
4赞 Luke 10/25/2018
令人难以置信的是,仅通过阅读标题就可以将问题标记为重复。
0赞 Ben Voigt 7/1/2021
在 Shog 的编辑之后,这确实是 stackoverflow.com/q/5800361/103167 的复制品但这个已经获得了更多的活动。

答:

187赞 Naveed 5/3/2011 #1

看看这个博客:

可以指定缓冲区大小,或者 可以使用默认大小。这 默认值对于大多数人来说已经足够大了 目的。

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

// Get the object of DataInputStream
DataInputStream in = new DataInputStream(fstream);
BufferedReader br = new BufferedReader(new InputStreamReader(in));

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
in.close();

评论

8赞 Aboozar Rajabi 11/10/2016
我的文件是 1.5 Gig,无法使用您的答案读取文件!
5赞 user207421 5/7/2017
@AboozarRajabi当然有可能。此代码可以读取任何文本文件。
12赞 user207421 5/7/2017
对质量差的链接投了反对票。有一个完全没有意义的,错误的流被关闭了。Java 教程没有错,也没有必要像这样随意引用第三方互联网垃圾。DataInputStream
6赞 Buffalo 10/24/2019
我会抛弃评论,你有 4 行 100% 冗余评论,用于 6 行代码。
0赞 user207421 9/25/2023
编辑已恢复。默默地纠正错误的答案是不可接受的。
7赞 Master C 5/3/2011 #2

您需要使用中的方法。 从该类创建一个新对象,并对他操作此方法并将其保存到字符串中。readLine()class BufferedReader

BufferReader Javadoc

10赞 Abhilash 5/3/2011 #3

您可以使用 Scanner 类

Scanner sc=new Scanner(file);
sc.nextLine();

评论

2赞 user207421 11/18/2013
@Tim“可怕地轰炸”不是我在 CS 中认识的术语。你到底是什么意思?
0赞 Tim 11/18/2013
陷入困境,执行速度非常慢,很可能会崩溃。我可能应该避免在这个网站上使用成语;)
4赞 xehpuk 2/23/2015
@Tim 为什么要这样做?
2赞 Aleksandr Dubinsky 3/8/2015
使用很好,但这个答案不包括正确使用它的完整代码。Scanner
5赞 user207421 8/3/2015
@Tim 这段代码既不会“可怕地轰炸”,也不会“陷入困境”,也不会“执行得很慢”,也不会“最有可能崩溃”。事实上,正如所写的那样,它几乎不会读一行。您可以通过这种方式每秒读取兆字节,尽管速度肯定是原来的几倍。如果您不这么认为,请提供您的理由。BufferedReader.readLine()
1233赞 Peter Lawrey 5/3/2011 #4

一种常见的模式是使用

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 稍后才关闭。

评论

6赞 MikeB 3/16/2013
在适当的异常处理下,这种模式是什么样子的?我注意到 br.close() 抛出 IOException,这似乎令人惊讶——无论如何,关闭打开读取的文件时会发生什么?FileReader 的构造函数可能会引发 FileNotFound 异常。
3赞 Jiew Meng 11/8/2013
如果我有一个 200MB 的文件并且它可以以 90MB/s 的速度读取,那么我预计它需要 ~3 秒?我的似乎需要几分钟,这种“缓慢”的阅读方式。我使用的是 SSD,所以读取速度应该不是问题吗?
5赞 Peter Lawrey 11/8/2013
@JiewMeng所以,我怀疑你正在做的其他事情需要时间。你能试着只阅读文件的行而没有其他东西吗?
53赞 Aleksandr Dubinsky 12/15/2013
为什么不顺便说一句,在 Java 8 中你可以做到 这很难不讨厌。for(String line = br.readLine(); line != null; line = br.readLine())try( Stream<String> lines = Files.lines(...) ){ for( String line : (Iterable<String>) lines::iterator ) { ... } }
33赞 Peter Lawrey 12/15/2013
@AleksandrDubinsky 我在 Java 8 中对闭包的问题是,它很容易使代码阅读起来更复杂(而且速度更慢),我可以看到很多开发人员过度使用它,因为它很“酷”。
41赞 DarkStar 3/27/2013 #5

下面是一个示例,其中包含完整的错误处理和支持 Java 7 之前的字符集规范。在 Java 7 中,您可以使用 try-with-resources 语法,这使代码更简洁。

如果只想要默认字符集,则可以跳过 InputStream 并使用 FileReader。

InputStream ins = null; // raw byte-stream
Reader r = null; // cooked reader
BufferedReader br = null; // buffered for readLine()
try {
    String s;
    if (true) {
        String data = "#foobar\t1234\n#xyz\t5678\none\ttwo\n";
        ins = new ByteArrayInputStream(data.getBytes());
    } else {
        ins = new FileInputStream("textfile.txt");
    }
    r = new InputStreamReader(ins, "UTF-8"); // leave charset out for default
    br = new BufferedReader(r);
    while ((s = br.readLine()) != null) {
        System.out.println(s);
    }
}
catch (Exception e)
{
    System.err.println(e.getMessage()); // handle exception
}
finally {
    if (br != null) { try { br.close(); } catch(Throwable t) { /* ensure close happens */ } }
    if (r != null) { try { r.close(); } catch(Throwable t) { /* ensure close happens */ } }
    if (ins != null) { try { ins.close(); } catch(Throwable t) { /* ensure close happens */ } }
}

这是 Groovy 版本,具有完整的错误处理功能:

File f = new File("textfile.txt");
f.withReader("UTF-8") { br ->
    br.eachLine { line ->
        println line;
    }
}

评论

1赞 user207421 5/7/2017
字符串文本的馈送与读取大型文本文件有什么关系?ByteArrayInputStream
1赞 Enerccio 6/19/2019
绝对没用的关闭。没有理由关闭每个流。如果您关闭其中任何一个流,则会自动关闭所有其他流...
132赞 msayag 7/26/2013 #6

Java 8 发布后(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);
}

评论

2赞 Aleksandr Dubinsky 12/15/2013
使用,简洁地使用,避免使用,特别是除非有理由。StandardCharsets.UTF_8Stream<String>forEach()forEachOrdered()
3赞 steventrouble 3/19/2014
为什么要避免 forEach()?不好吗?
1赞 msayag 3/20/2014
如果我使用 forEach 而不是 forEachOrdered,则这些行可能会按顺序打印,不是吗?
2赞 Aleksandr Dubinsky 3/8/2015
@steventrouble 看一看:stackoverflow.com/questions/16635398/...如果你传递一个简短的函数引用,比如 ,这还不错,但如果你在里面写代码块作为 lambda,它会变得很丑陋。forEach(this::process)forEach()
2赞 Aleksandr Dubinsky 3/8/2015
@msayag,你是对的,你需要按顺序执行。请注意,在这种情况下,您将无法并行化流,尽管我发现除非文件有数千行,否则并行化不会打开。forEachOrdered
20赞 Aleksandr Dubinsky 12/15/2013 #7

在 Java 8 中,您可以执行以下操作:

try (Stream<String> lines = Files.lines (file, StandardCharsets.UTF_8))
{
    for (String line : (Iterable<String>) lines::iterator)
    {
        ;
    }
}

一些注意事项:返回的流(与大多数流不同)需要关闭。由于这里提到的原因,我避免使用 .奇怪的代码将 Stream 强制转换为 Iterable。Files.linesforEach()(Iterable<String>) lines::iterator

评论

0赞 Stephan 12/15/2013
如果不实现,这段代码虽然有用,但绝对是丑陋的。它需要一个演员表(即)才能工作。Iterable(Iterable<String>)
0赞 qed 11/6/2014
如何使用此方法跳过第一行?
2赞 Aleksandr Dubinsky 11/12/2014
@qedfor(String line : (Iterable<String>) lines.skip(1)::iterator)
1赞 Holger 7/28/2017
如果您不打算实际使用功能,那么使用而不是重复调用,直到而不是使用这样的构造似乎要简单得多......StreamFiles.newBufferedReaderFiles.linesreadLine()null(Iterable<String>) lines::iterator
1赞 Aleksandr Dubinsky 9/23/2019
@user207421 为什么说它会将文件读入内存?javadoc 说,Unlike readAllLines, [File.lines] does not read all lines into a List, but instead populates lazily as the stream is consumed... The returned stream encapsulates a Reader.
16赞 Diego Duarte 4/9/2014 #8

在 Java 7 中:

String folderPath = "C:/folderOfMyFile";
Path path = Paths.get(folderPath, "myFileName.csv"); //or any text file eg.: txt, bat, etc
Charset charset = Charset.forName("UTF-8");

try (BufferedReader reader = Files.newBufferedReader(path , charset)) {
  while ((line = reader.readLine()) != null ) {
    //separate all csv fields into string array
    String[] lineVariables = line.split(","); 
  }
} catch (IOException e) {
    System.err.println(e);
}

评论

9赞 Marcelo Finki 10/13/2014
请注意!如果字段包含逗号并且用引号括起来,则以这种方式使用 line.split 将无法正确解析。这种拆分将忽略这一点,而只是使用内部逗号将字段分成块。HTH,马塞洛。
0赞 Diego Duarte 2/19/2015
CSV:逗号分隔值文件,因此您不应该在 csv 字段中使用逗号,除非您打算添加另一个字段。因此,在解析 CSV 文件时,在 java 中使用逗号标记的拆分是完全可以的
7赞 serg.nechaev 2/27/2015
迭戈,这是不正确的。唯一的 CSV 标准 (RFC 4180) 明确指出“包含换行符 (CRLF)、双引号和逗号的字段应用双引号括起来。
2赞 Aleksandr Dubinsky 3/8/2015
用于避免StandardCharsets.UTF_8Charset.forName("UTF-8")
2赞 Marcelo Finki 3/13/2015
感谢“迭戈·杜阿尔特”的评论;我必须说我同意“serg.nechaev”的回答。我“一直”看到 csv 文件中嵌入了逗号。人们希望这将被接受。恕我直言。也非常感谢“serg.nechaev”。恕我直言,你是对的。为大家干杯。
8赞 Abdennour TOUMI 5/20/2014 #9

Java 9:

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

评论

2赞 SpringLearner 7/9/2015
我认为你必须这样做System.getProperty("os.name").equals("Linux")
5赞 Jonas Czech 6/7/2016
不要将字符串与 !==
11赞 Holger 7/28/2017
这是规范的 Java 8 示例,正如其他人已经发布的那样。你为什么声称这是“Java-9”?
0赞 Eugene 7/29/2017
他忘了提及的内存映射文件可能@Holger?
0赞 thanos.a 11/1/2019
要逐行处理它,您可以尝试 (Stream<String> stream = Files.lines(Paths.get(inputFile))) { stream.forEach((line) -> { System.out.println(line); };
18赞 live-love 1/27/2015 #10

FileReader 不允许指定编码,如果需要指定编码,请改用:InputStreamReader

try {
    BufferedReader br = new BufferedReader(new InputStreamReader(new FileInputStream(filePath), "Cp1252"));         

    String line;
    while ((line = br.readLine()) != null) {
        // process the line.
    }
    br.close();

} catch (IOException e) {
    e.printStackTrace();
}

如果从 Windows 导入此文件,它可能具有 ANSI 编码 (Cp1252),因此必须指定编码。

-1赞 To Kra 4/22/2015 #11

您还可以使用 Apache Commons IO:

File file = new File("/home/user/file.txt");
try {
    List<String> lines = FileUtils.readLines(file);
} catch (IOException e) {
    // TODO Auto-generated catch block
    e.printStackTrace();
}

评论

6赞 Parker 6/22/2015
FileUtils.readLines(file)是已弃用的方法。此外,该方法调用 IOUtils.readLines,后者使用 BufferedReader 和 ArrayList。这不是一种逐行的方法,当然也不是一种用于读取几 GB 的方法。
2赞 Binkan Salaryman 5/22/2015 #12

我通常直接做阅读程序:

void readResource(InputStream source) throws IOException {
    BufferedReader stream = null;
    try {
        stream = new BufferedReader(new InputStreamReader(source));
        while (true) {
            String line = stream.readLine();
            if(line == null) {
                break;
            }
            //process line
            System.out.println(line)
        }
    } finally {
        closeQuiet(stream);
    }
}

static void closeQuiet(Closeable closeable) {
    if (closeable != null) {
        try {
            closeable.close();
        } catch (IOException ignore) {
        }
    }
}
15赞 Rüdiger Herrmann 7/7/2015 #13

在 Java 8 中,还有一种使用 Files.lines() 的替代方法。如果你的输入源不是文件,而是更抽象的东西,比如 a 或 an ,你可以通过 s 方法流式传输这些行。ReaderInputStreamBufferedReaderlines()

例如:

try (BufferedReader reader = new BufferedReader(...)) {
  reader.lines().forEach(line -> processLine(line));
}

将调用 读取的每个输入行。processLine()BufferedReader

21赞 iskandarchacra 9/13/2015 #14

您可以做的是使用扫描仪扫描整个文本并逐行浏览文本。 当然,您应该导入以下内容:

import java.io.File;
import java.io.FileNotFoundException;
import java.util.Scanner;
public static void readText throws FileNotFoundException {
    Scanner scan = new Scanner(new File("samplefilename.txt"));
    while(scan.hasNextLine()){
        String line = scan.nextLine();
        //Here you can manipulate the string the way you want
    }
}

扫描仪基本上会扫描所有文本。while 循环用于遍历整个文本。

该函数是一个布尔值,如果文本中还有更多行,则返回 true。该函数以 String 的形式为您提供一整行,然后您可以按照自己的方式使用它。尝试打印文本。.hasNextLine().nextLine()System.out.println(line)

旁注:.txt是文件类型文本。

评论

0赞 Ketcomp 1/27/2016
方法声明不应该看起来而不是这样: 'public static void readText throws FileNotFoundException(){' Like: 'public static void readText() throws FileNotFoundException{'
0赞 user207421 5/7/2017
这比 要慢得多,他要求采用性能最好的方法。BufferedReader.readLine()
6赞 Rajamohan S 8/20/2016 #15

实现这一目标的明确方法,

例如:

如果您在当前目录上有dataFile.txt

import java.io.*;
import java.util.Scanner;
import java.io.FileNotFoundException;

public class readByLine
{
    public readByLine() throws FileNotFoundException
    {
        Scanner linReader = new Scanner(new File("dataFile.txt"));

        while (linReader.hasNext())
        {
            String line = linReader.nextLine();
            System.out.println(line);
        }
        linReader.close();

    }

    public static void main(String args[])  throws FileNotFoundException
    {
        new readByLine();
    }
}

输出如下,enter image description here

评论

0赞 user207421 10/28/2016
为什么更清楚?不要在这里发布文字图片。发布文本。
0赞 user207421 5/7/2017
你发布了一张照片。这是一幅文字图片。您可以将文本直接剪切并粘贴到此页面中。没有人说任何关于发布程序的事情。发布文字图片是浪费你的时间,我不在乎,而我关心的是带宽。
13赞 Ankit Sood 4/20/2017 #16

用于使用 Java 8 读取文件

package com.java.java8;

import java.nio.file.Files;
import java.nio.file.Paths;
import java.util.stream.Stream;

/**
 * The Class ReadLargeFile.
 *
 * @author Ankit Sood Apr 20, 2017
 */
public class ReadLargeFile {

    /**
     * The main method.
     *
     * @param args
     *            the arguments
     */
    public static void main(String[] args) {
        try {
            Stream<String> stream = Files.lines(Paths.get("C:\\Users\\System\\Desktop\\demoData.txt"));
            stream.forEach(System.out::println);
        }
        catch (Exception e) {
            // TODO Auto-generated catch block
            e.printStackTrace();
        }
    }
}
3赞 Dipendra Ghatal 9/17/2017 #17
BufferedReader br;
FileInputStream fin;
try {
    fin = new FileInputStream(fileName);
    br = new BufferedReader(new InputStreamReader(fin));

    /*Path pathToFile = Paths.get(fileName);
    br = Files.newBufferedReader(pathToFile,StandardCharsets.US_ASCII);*/

    String line = br.readLine();
    while (line != null) {
        String[] attributes = line.split(",");
        Movie movie = createMovie(attributes);
        movies.add(movie);
        line = br.readLine();
    }
    fin.close();
    br.close();
} catch (FileNotFoundException e) {
    System.out.println("Your Message");
} catch (IOException e) {
    System.out.println("Your Message");
}

它对我有用。希望它也能帮助你。

3赞 spidy 9/22/2017 #18

您可以使用流来更精确地执行此操作:

Files.lines(Paths.get("input.txt")).forEach(s -> stringBuffer.append(s);

评论

2赞 Andrii Rubtsov 4/20/2018
我同意这实际上很好。Aguess,人们不喜欢它,因为奇怪的 StringBuffer 选择(StringBuilder 通常是首选,即使它可能只是变量的一个坏名字)。也因为上面已经提到过。
-1赞 Usman 10/27/2017 #19

您可以使用以下代码:

import java.io.BufferedReader;
import java.io.File;
import java.io.FileReader;
import java.io.IOException;

public class ReadTextFile {

    public static void main(String[] args) throws IOException {

        try {

            File f = new File("src/com/data.txt");

            BufferedReader b = new BufferedReader(new FileReader(f));

            String readLine = "";

            System.out.println("Reading file using Buffered Reader");

            while ((readLine = b.readLine()) != null) {
                System.out.println(readLine);
            }

        } catch (IOException e) {
            e.printStackTrace();
        }

    }

}

评论

1赞 Peter Mortensen 4/9/2020
解释是有道理的。
0赞 user207421 8/31/2022
具体来说,解释为什么这构成“快速”,而不是所有其他方法。无需初始化变量。readLine
28赞 gomisha 4/8/2018 #20

我记录并测试了 10 种不同的方法来读取 Java 中的文件,然后通过让它们在 1KB 到 1GB 的测试文件中读取来相互运行它们。以下是读取 1GB 测试文件最快的 3 种文件读取方法。

请注意,在运行性能测试时,我没有向控制台输出任何内容,因为这确实会减慢测试速度。我只是想测试原始阅读速度。

1) java.nio.file.Files.readAllBytes()

在 Java 7、8、9 中测试。总的来说,这是最快的方法。读取 1GB 文件始终不到 1 秒。

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

public class ReadFile_Files_ReadAllBytes {
  public static void main(String [] pArgs) throws IOException {
    String fileName = "c:\\temp\\sample-1GB.txt";
    File file = new File(fileName);

    byte [] fileBytes = Files.readAllBytes(file.toPath());
    char singleChar;
    for(byte b : fileBytes) {
      singleChar = (char) b;
      System.out.print(singleChar);
    }
  }
}

2) java.nio.file.Files.lines()

这在 Java 8 和 9 中测试成功,但由于缺乏对 lambda 表达式的支持,它在 Java 7 中不起作用。读取 1GB 文件大约需要 3.5 秒,这在读取较大文件方面排名第二。

import java.io.File;
import java.io.IOException;
import java.nio.file.Files;
import java.util.stream.Stream;

public class ReadFile_Files_Lines {
  public static void main(String[] pArgs) throws IOException {
    String fileName = "c:\\temp\\sample-1GB.txt";
    File file = new File(fileName);

    try (Stream linesStream = Files.lines(file.toPath())) {
      linesStream.forEach(line -> {
        System.out.println(line);
      });
    }
  }
}

3) 缓冲读卡器

经测试可在 Java 7、8、9 中工作。读取 1GB 测试文件大约需要 4.5 秒。

import java.io.BufferedReader;
import java.io.FileReader;
import java.io.IOException;

public class ReadFile_BufferedReader_ReadLine {
  public static void main(String [] args) throws IOException {
    String fileName = "c:\\temp\\sample-1GB.txt";
    FileReader fileReader = new FileReader(fileName);

    try (BufferedReader bufferedReader = new BufferedReader(fileReader)) {
      String line;
      while((line = bufferedReader.readLine()) != null) {
        System.out.println(line);
      }
    }
  }

您可以在此处找到所有 10 种文件读取方法的完整排名。

评论

2赞 Faisal Julaidan 5/23/2018
你的导游太棒了:)
2赞 user207421 9/12/2019
你主要是在这里计时;您还假设该文件在前两种情况下适合内存。System.out.print/println()
0赞 gomisha 9/13/2019
很公平。也许我可以在我的回答中更明确地说明这些假设。
3赞 eis 10/28/2020
要求逐行阅读的问题,只有最后一种方法符合条件......
0赞 Blue Dev 7/19/2022
@eis 鉴于他测试了 10 种读取文件的方法,并且第三快的是逐行读取,因此可以合理地假设此处显示的第三种方法也是逐行读取文件的最快方法。我认为,他不仅完全回答了这个问题,而且还提供了其他信息,这些信息非常有用。
1赞 mohsen.nour 1/19/2019 #21

通过使用 org.apache.commons.io 包,它提供了更高的性能,尤其是在使用 Java 6 及更低版本的遗留代码中。

Java 7 具有更好的 API,异常更少 处理和更有用的方法:

LineIterator lineIterator = null;
try {
    lineIterator = FileUtils.lineIterator(new File("/home/username/m.log"), "windows-1256"); // The second parameter is optionnal
    while (lineIterator.hasNext()) {
        String currentLine = lineIterator.next();
        // Some operation
    }
}
finally {
    LineIterator.closeQuietly(lineIterator);
}

Maven的

<!-- https://mvnrepository.com/artifact/commons-io/commons-io -->
<dependency>
    <groupId>commons-io</groupId>
    <artifactId>commons-io</artifactId>
    <version>2.6</version>
</dependency>
-2赞 Mahozad 12/18/2022 #22

对于最终来到这里的 Android 开发人员(使用 Kotlin 的人):

val myFileUrl = object{}.javaClass.getResource("/vegetables.txt")
val file = File(myFileUrl.toURI())
file
    .bufferedReader()
    .lineSequence()
    .forEach(::println)

艺术

val myFileUrl = object{}.javaClass.getResource("/vegetables.txt")
val file = File(myFileUrl.toURI())
file.useLines { lines ->
    lines.forEach(::println)
}

笔记:

  • vegetables.txt 文件应位于类路径中(例如,在 src/main/resources 目录中)

  • 上述解决方案都默认将文件编码视为文件编码。您可以将所需的编码指定为函数的参数。UTF-8

  • 上述解决方案不需要任何进一步的操作,例如关闭文件或读取器。它们由 Kotlin 标准库自动处理。