NodeJs----fs模块(文件读取流 写入流 管道流)

时间:2024-03-26 11:26:01

原始:

EventEmitter:

events 模块只提供了一个对象: events.EventEmitter。EventEmitter 的核心就是事件触发与事件监听器功能的封装。

// 10 fs.createReadStream 从文件流中读取数据
let fs = require('fs');

let fileReadStream = fs.createReadStream('./package.json');
let count = 0;
let str = '';
//读取数据内置的事件监听
fileReadStream.on('data',(chunk) => {
    console.log(`${++count}接收到:${chunk.length}`);
    str += chunk;
})
fileReadStream.on('end',() => {
    console.log('---结束---');
    console.log(`最终读取到数据为:${str}`);
    writeData(str);
})
fileReadStream.on('error',(error) => {
    console.log(error)
})

function writeData(str){
    //11 fs.createWriteStream 写入文件
    // 创建一个可以写入的流,写入到文件 package22.json 中
    let writerStream = fs.createWriteStream('./package22.json');
    // 使用 utf8 编码写入数据
    writerStream.write(str,'UTF8');
    // 标记文件末尾
    writerStream.end();
    // 处理流事件 --> finish 事件
    writerStream.on('finish',() => { //finish - 所有数据已被写入到底层系统时触发。
        console.log('写入完成');
    })
    writerStream.on('error',(err) => {
        console.log(err.stack);
    })
    console.log("程序执行完毕");
}

简化:

管道流:
管道提供了一个输出流到输入流的机制。通常我们用于从一个流中获取数据并将数据传递到另外一个流中。

NodeJs----fs模块(文件读取流 写入流 管道流)

如上面的图片所示,我们把文件比作装水的桶,而水就是文件里的内容,我们用一根管子(pipe)连接两个桶使得水从一个
桶流入另一个桶,这样就慢慢的实现了大文件的复制过程。
以下实例我们通过读取一个文件内容并将内容写入到另外一个文件中。

let fs = require('fs');

//12 管道流来读取写入
// 创建一个可读流
var readerStream = fs.createReadStream('./package.json');
// 创建一个可写流
var writerStream = fs.createWriteStream('./package22.json');
// 管道读写操作
// 读取 package.json 文件内容,并将内容写入到 package22.json 文件中
readerStream.pipe(writerStream);