逐行读取文件的能力允许我们读取大文件,而无需将其全部存储到内存中。它有助于节省资源和提高应用程序的效率。
它允许我们寻找所需的信息,一旦找到了相关的信息,我们可以停止搜索过程,可以防止不必要的内存使用。
我们将使用Readline模块和Line-Reader模块来实现这一目标。
方法一 readline
使用Readline模块:Readline是Node的原生模块。它是专门为从任何可读流逐行读取内容而开发的。它可用于从命令行读取数据。
因为模块是Node的本机模块。js,它不需要任何安装,可以直接导入:
const readline = require('readline');
因为readline模块只适用于可读流,所以我们需要首先使用fs模块创建可读流。
const file = readline.createInterface({ input: fs.createReadStream('source_to_file'), output: process.stdout, terminal: false });
现在,监听file对象上的line事件。每当从流中读取新行时,事件就会触发:
file.on('line', (line) => { console.log(line); });
例:
// Importing the Required Modules const fs = require('fs'); const readline = require('readline'); // Creating a readable stream from file // readline module reads line by line // but from a readable stream only. const file = readline.createInterface({ input: fs.createReadStream('gfg.txt'), output: process.stdout, terminal: false }); // Printing the content of file line by // line to console by listening on the // line event which will triggered // whenever a new line is read from // the stream file.on('line', (line) => { console.log(line); });
方法二 line-reader
使用line-reader模块:line-reader模块是Node.js中逐行读取文件的开源模块。它不是本地模块,所以你需要使用npm(节点包管理器)安装它,使用命令:
npm install line-reader --save
行读取器模块提供了逐行读取文件的eachLine()方法。
它有一个回调函数,该函数有两个参数:行内容和一个布尔值,该值存储是否读取的行是文件的最后一行。
const lineReader = require('line-reader'); lineReader.eachLine('source-to-file', (line, last) => { console.log(line); });
例:
// Importing required libraries const lineReader = require('line-reader'); // eachLine() method call on gfg.txt // It got a callback function // Printing content of file line by line // on the console lineReader.eachLine('gfg.txt', (line, last) => { console.log(line); });
输出:
更多关于node.js readline和line-reader逐行读取文件方法请查看下面的相关链接