Node.js Stream(流)
Node.js Stream(流)
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(); // 处理惩罚流事件 --> data, end, and 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 文件解压完成。