Node.js Stream(流)

简介: 10月更文挑战第4天

Stream 是一个抽象接口,Node 中有很多对象实现了这个接口。例如,对http 服务器发起请求的request 对象就是一个 Stream,还有stdout(标准输出)。

Node.js,Stream 有四种流类型:

  • Readable - 可读操作。
  • Writable - 可写操作。
  • Duplex - 可读可写操作.
  • Transform - 操作被写入数据,然后读出结果。

所有的 Stream 对象都是 EventEmitter 的实例。常用的事件有:

  • data - 当有数据可读时触发。
  • end - 没有更多的数据可读时触发。
  • error - 在接收和写入过程中发生错误时触发。
  • finish - 所有数据已被写入到底层系统时触发。

本教程会为大家介绍常用的流操作。


从流中读取数据

创建 input.txt 文件,内容如下:

菜鸟教程官网地址:www.runoob.com

创建 main.js 文件, 代码如下:

var fs = require("fs");

var data = '';


// 创建可读流

var readerStream = fs.createReadStream('input.txt');


// 设置编码为 utf8。

readerStream.setEncoding('UTF8');


// 处理流事件 --> data, end, and error

readerStream.on('data', function(chunk) {

  data += chunk;

});


readerStream.on('end',function(){

  console.log(data);

});


readerStream.on('error', function(err){

  console.log(err.stack);

});


console.log("程序执行完毕");

以上代码执行结果如下:

程序执行完毕

菜鸟教程官网地址:www.runoob.com


写入流

创建 main.js 文件, 代码如下:

var fs = require("fs");

var data = '菜鸟教程官网地址:www.runoob.com';


// 创建一个可以写入的流,写入到文件 output.txt 中

var writerStream = fs.createWriteStream('output.txt');


// 使用 utf8 编码写入数据

writerStream.write(data,'UTF8');


// 标记文件末尾

writerStream.end();


// 处理流事件 --> finish、error

writerStream.on('finish', function() {

   console.log("写入完成。");

});


writerStream.on('error', function(err){

  console.log(err.stack);

});


console.log("程序执行完毕");

以上程序会将 data 变量的数据写入到 output.txt 文件中。代码执行结果如下:

$ node main.js

程序执行完毕

写入完成。

查看 output.txt 文件的内容:

$ cat output.txt

菜鸟教程官网地址:www.runoob.com


管道流

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

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

以下实例我们通过读取一个文件内容并将内容写入到另外一个文件中。

设置 input.txt 文件内容如下:

菜鸟教程官网地址:www.runoob.com

管道流操作实例

创建 main.js 文件, 代码如下:

var fs = require("fs");


// 创建一个可读流

var readerStream = fs.createReadStream('input.txt');


// 创建一个可写流

var writerStream = fs.createWriteStream('output.txt');


// 管道读写操作

// 读取 input.txt 文件内容,并将内容写入到 output.txt 文件中

readerStream.pipe(writerStream);


console.log("程序执行完毕");

代码执行结果如下:

$ node main.js

程序执行完毕

查看 output.txt 文件的内容:

$ cat output.txt

菜鸟教程官网地址:www.runoob.com

管道流操作实例


链式流

链式是通过连接输出流到另外一个流并创建多个流操作链的机制。链式流一般用于管道操作。

接下来我们就是用管道和链式来压缩和解压文件。

创建 compress.js 文件, 代码如下:

var fs = require("fs");

var zlib = require('zlib');


// 压缩 input.txt 文件为 input.txt.gz

fs.createReadStream('input.txt')

 .pipe(zlib.createGzip())

 .pipe(fs.createWriteStream('input.txt.gz'));

 

console.log("文件压缩完成。");

代码执行结果如下:

$ node compress.js

文件压缩完成。

执行完以上操作后,我们可以看到当前目录下生成了 input.txt 的压缩文件 input.txt.gz。

接下来,让我们来解压该文件,创建 decompress.js 文件,代码如下:

var fs = require("fs");

var zlib = require('zlib');


// 解压 input.txt.gz 文件为 input.txt

fs.createReadStream('input.txt.gz')

 .pipe(zlib.createGunzip())

 .pipe(fs.createWriteStream('input.txt'));

 

console.log("文件解压完成。");

代码执行结果如下:

$ node decompress.js

文件解压完成。

目录
相关文章
|
7月前
|
消息中间件 Web App开发 JavaScript
Node.js【简介、安装、运行 Node.js 脚本、事件循环、ES6 作业队列、Buffer(缓冲区)、Stream(流)】(一)-全面详解(学习总结---从入门到深化)
Node.js【简介、安装、运行 Node.js 脚本、事件循环、ES6 作业队列、Buffer(缓冲区)、Stream(流)】(一)-全面详解(学习总结---从入门到深化)
301 0
|
7月前
|
JavaScript 前端开发 API
Node.js【简介、安装、运行 Node.js 脚本、事件循环、ES6 作业队列、Buffer(缓冲区)、Stream(流)】(一)-全面详解(学习总结---从入门到深化)(下)
Node.js【简介、安装、运行 Node.js 脚本、事件循环、ES6 作业队列、Buffer(缓冲区)、Stream(流)】(一)-全面详解(学习总结---从入门到深化)
101 0
|
7月前
|
消息中间件 Web App开发 JavaScript
Node.js【简介、安装、运行 Node.js 脚本、事件循环、ES6 作业队列、Buffer(缓冲区)、Stream(流)】(一)-全面详解(学习总结---从入门到深化)(上)
Node.js【简介、安装、运行 Node.js 脚本、事件循环、ES6 作业队列、Buffer(缓冲区)、Stream(流)】(一)-全面详解(学习总结---从入门到深化)
197 0
|
5月前
|
JavaScript
Node.js 流 Stream【详解】
Node.js 流 Stream【详解】
49 4
|
6月前
|
JavaScript
Node.js Stream(流)
Node.js Stream(流)
35 0
|
7月前
|
JavaScript 算法 网络协议
【Node系列】node中的流(Stream)
Node.js 中的流(Stream)是一种处理数据的方式,它允许你以流的方式处理数据,而不是一次性加载整个数据集。这种方式对于处理大量数据非常有用,因为它可以减少内存的使用并提高性能。
77 4
|
7月前
|
JavaScript 网络协议 数据处理
Node.js中的Buffer与Stream:深入解析与使用
【4月更文挑战第30天】本文深入解析了Node.js中的Buffer和Stream。Buffer是处理原始数据的全局对象,适用于TCP流和文件I/O,其大小在V8堆外分配。创建Buffer可通过`alloc`和`from`方法,它提供了读写、切片和转换等操作。Stream是处理流式数据的抽象接口,分为可读、可写、双工和转换四种类型,常用于处理大量数据而无需一次性加载到内存。通过监听事件和调用方法,如读取文件的可读流示例,可以实现高效的数据处理。理解和掌握Buffer及Stream能提升Node.js应用的性能。
|
7月前
|
JavaScript 大数据 数据处理
什么是Node.js的流(stream)?它们有什么作用?
什么是Node.js的流(stream)?它们有什么作用?
99 3
|
7月前
|
存储 JavaScript 网络协议
什么是Node.js Stream(流)?
什么是Node.js Stream(流)?
93 0
|
存储 运维 JavaScript
【Node.js实战】一文带你开发博客项目之日志(文件读写、stream流、写日志)
【Node.js实战】一文带你开发博客项目之日志(文件读写、stream流、写日志)
269 3