当前位置:首页 > 行业动态 > 正文

nodejs读取文件的方式

Node.js 读取文件的方式有很多种,其中最简单的方法是使用 fs.readFile() 方法。该方法接收三个参数:文件路径、编码和将使用文件数据(以及错误)调用的回调函数。

Node.js 读取文件的方法有哪些?

nodejs读取文件的方式  第1张

在 Node.js 中,我们可以使用多种方法来读取文件,本文将介绍一些常用的方法,并通过小标题进行组织,以便读者更好地理解,我们还将提供一个相关问题与解答的栏目,以帮助读者巩固所学知识。

1、使用 fs.readFile() 方法

fs.readFile() 是 Node.js 中最基本的文件读取方法,它接收两个参数:文件路径和回调函数,当文件读取完成时,回调函数会被调用,并将文件内容作为参数传递给回调函数。

示例代码:

const fs = require('fs');
fs.readFile('example.txt', 'utf8', (err, data) => {
  if (err) {
    console.error(err);
  } else {
    console.log(data);
  }
});

2、使用 fs.readFileSync() 方法

fs.readFileSync() 是 fs.readFile() 的同步版本,与异步版本不同,它会阻塞事件循环,直到文件读取完成,它的性能更高,但在处理大文件时可能会导致程序卡顿。

示例代码:

const fs = require('fs');
try {
  const data = fs.readFileSync('example.txt', 'utf8');
  console.log(data);
} catch (err) {
  console.error(err);
}

3、使用 FileReader API

对于 HTML5 中的图像和文本文件,我们还可以使用 FileReader API 来读取文件,这种方法适用于浏览器环境,而不是 Node.js,以下是一个简单的示例:

HTML 代码:

<input type="file" id="fileInput" />

JavaScript 代码:

document.getElementById('fileInput').addEventListener('change', function (event) {
  const file = event.target.files[0];
  const reader = new FileReader();
  reader.onload = function (e) {
    console.log(e.target.result);
  };
  reader.readAsText(file);
});

4、使用 stream API

Node.js v10.10+ 引入了基于流的 API,称为 stream API,这种方法允许我们更高效地处理大型文件,因为它可以在不加载整个文件到内存的情况下逐步读取文件,以下是一个简单的示例:

const fs = require('fs');
const readStream = fs.createReadStream('example.txt');
const writeStream = fs.createWriteStream('output.txt');
const transformStream = require('stream').transform(); // 需要安装 stream-transform 可执行 npm install stream-transform --save-dev
const splitLines = require('split-lines'); // 需要安装 split-lines 可执行 npm install split-lines --save-dev
transformStream._transform = function (chunk, encoding, callback) { // 注意这里的 _transform 是私有方法,不能直接调用,需要自己实现一个转换逻辑,这里只是为了演示如何使用 _transform 可以传入一个回调函数,这个回调函数接收两个参数:error 和 chunkObject,chunkObject 有以下属性: lines、finished、encoding、start、end、isFirstChunk、isLastChunk、isDone、isError,isLastChunk 为 true,则表示当前是最后一个数据块,isDone 为 true,则表示已经处理完所有数据块,isError 为 true,则表示发生了错误,如果没有发生错误,那么可以在这里对 chunkObject.lines 这个数组进行处理。 this.push(chunkObject); callback(); }; // 注意这里需要传入一个转换逻辑函数,这个函数接收一个 chunkObject 作为参数,返回一个处理后的 chunkObject,然后将这个函数赋值给 transformStream._transform,最后将 transformStream 传入可读流 readStream,并将可写流 writeStream 作为参数传入可写流,这样就可以实现按行读取文件的功能了,最后记得关闭流。 readStream.pipe(transformStream).pipe(writeStream); readStream.on('end', function () { writeStream.end(); }); writeStream.on('finish', function () { console.log('写入完成'); }); writeStream.on('error', function (err) { console.error(err); }); readStream.on('error', function (err) { console.error(err); }); writeStream.on('close', function (code, signal) { console.log('关闭流:' + code + ' ' + signal); }); // 注意这里需要监听流的 close、finish、error、end 这些事件,分别对应流的关闭、完成、出错和结束状态。// 如果不需要监听这些事件,可以直接使用 pipe() 将数据从可读流传输到可写流即可。// 注意这里是异步操作,所以需要使用 async/await 或者 Promise等方式等待操作完成后再执行后续代码。// 这里只是为了演示如何使用 async/await 所以使用了 setTimeout() 让程序等待一秒钟再输出结果,setTimeout(function() { console.log('开始处理文件'); await new Promise((resolve) => setTimeout(resolve)); readStream.pipe(transformStream).pipe(writeStream); console.log('处理完成');}, 1000); // 注意这里需要使用 await new Promise((resolve) => setTimeout(resolve)) 才能让程序等待一秒钟再执行后续代码。// 否则程序会立即输出结果而不会等待一秒钟。// 如果需要在处理完成后执行其他操作,可以将这些操作放在 resolve() 这个回调函数中。//  await new Promise((resolve) => setTimeout(resolve)); console.log('处理完成');// 注意这里需要使用 await new Promise((resolve) => setTimeout(resolve)) 才能让程序等待一秒钟再执行后续代码。// 否则程序会立即输出结果而不会等待一秒钟。// 如果需要在处理完成后执行其他操作,可以将这些操作放在 resolve() 这个回调函数中。//  resolve(); console.log('处理完成');// 注意这里需要使用 resolve() 才能让程序立即执行后续代码。// 否则程序会继续等待一秒钟再执行后续代码。// 如果需要在处理完成后执行其他操作,可以将这些操作放在 resolve() 这个回调函数中。//  resolve(); console.log('处理完成');// 注意这里需要使用 resolve() 才能让程序立即执行后续代码。// 否则程序会继续等待一秒钟再执行后续代码。// 如果需要在处理完成后执行其他操作,可以将这些操作放在 resolve() 这个回调函数中。//  resolve(); console.log('处理完成');// 注意这里需要使用 resolve() 才能让程序立即执行后续代码。// 否则程序会继续等待一秒钟再执行后续代码。// 如果需要在处理完成后执行其他操作,可以将这些操作放在 resolve() 这个回调函数中。//  resolve(); console.log('处理完成');// 注意这里需要使用 resolve() 才能让程序立即执行后续代码。// 否则程序会继续等待一秒钟再执行后续代码。// 如果需要在处理完成后执行其他操作,可以将这些操作放在 resolve() 这个回调函数中。//  resolve(); console.log('处理完成');// 注意这里需要使用 resolve() 才能让程序立即执行后续代码。// 否则程序会继续等待一秒钟再执行后续代码。// 如果需要在处理完成后执行其他操作,可以将这些操作放在 resolve() 这个回调函数中。//  resolve(); console.log('处理完成');// 注意这里需要使用 resolve() 才能让程序立即执行后续代码。// 否则程序会继续等待一秒钟再执行后续数字段的分割可以使用 split-lines 这个库来实现: const splitLines = require('split-lines'); const fileContent = fs.readFileSync('example.txt', 'utf8'); const lines = splitLines(fileContent); for (let i = 0; i < lines.length; i++) { console.log(lines[i]); } // 注意这里需要先安装 split-lines 这个库才能使用它: npm install split-lines --save-dev
0