您现在的位置是:网站首页> 编程资料编程资料
node.js readline和line-reader逐行读取文件方法_node.js_
2023-05-24
327人已围观
简介 node.js readline和line-reader逐行读取文件方法_node.js_
逐行读取文件的能力允许我们读取大文件,而无需将其全部存储到内存中。它有助于节省资源和提高应用程序的效率。
它允许我们寻找所需的信息,一旦找到了相关的信息,我们可以停止搜索过程,可以防止不必要的内存使用。
我们将使用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); });
其它网友的代码
const fs = require('fs'); const readline = require('readline'); let rl = readline.createInterface({ input: fs.createReadStream("./11.txt") }) rl.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); }); 输出:

方法三 通过stream的方式
思路:通过流的形式,每次读取一个字节,然后判断这个子节是否是换行符(在mac中换行符为0xa0)
如果不是,则把该字节保存到 临时的数组中,如果是则把这些数组通过Buffer的形式转码utf8
下面的案例是:读取一个文件,然后给每行加行 “”,放到一个数组中,然后写入到新的文件中。
const fs = require("fs"); let readStream = fs.createReadStream("./11.txt"); let writeStream = fs.createWriteStream("./11_11.txt"); let buffer = []; function writeFileWithLine(line, isLastLine) { writeStream.write('\t"'); writeStream.write(line); if (isLastLine) { writeStream.write('"\n') } else { writeStream.write('",\n'); } } writeStream.write("[\n"); readStream.on("readable", () => { while ((char = readStream.read(1)) !== null) { if (char[0] === 0x0a) { writeFileWithLine(Buffer.from(buffer).toString(), false); buffer.length = 0; } else { buffer.push(char[0]); } } }); readStream.on("end", () => { writeFileWithLine(Buffer.from(buffer).toString(), true); writeStream.write("]"); });更多关于node.js readline和line-reader逐行读取文件方法请查看下面的相关链接
相关内容
- node.js读取命令行参数详解_node.js_
- 老生常谈Vue中的侦听器watch_vue.js_
- vite vue3 规范化与Git Hooks详解_vue.js_
- vue3 element的Form表单用法实例_vue.js_
- JavaScript日拱算法题解滑动窗口的最大值示例_JavaScript_
- 从柯里化分析JavaScript重要的高阶函数实例_javascript技巧_
- React之echarts-for-react源码解读_React_
- js数组直接赋值的问题(js数组的浅拷贝与深拷贝方法)_基础知识_
- JavaScript实现擦玻璃效果分析鼠标移动响应时间粒度问题_javascript技巧_
- 前端axios取消请求总结详解_vue.js_
