Stream
Node.js提供了四种流
-
Readable - 可读的流 (例如 fs.createReadStream()).
-
Writable - 可写的流 (例如 fs.createWriteStream()).
-
Duplex - 可读写的流 (例如 net.Socket).
-
Transform - 在读写过程中可以修改和变换数据的 Duplex 流 (例如 zlib.createDeflate()).
从流中读取数据
创建 mytext.txt 文件,内容如下:
测试DEMO
创建 demo5.js 文件, 代码如下:
var fs = require("fs");
var data = '';
// 创建可读流
var readerStream = fs.createReadStream('mytext.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("程序执行完毕");
代码输出结果:
程序执行完毕
测试DEMO
写入流
创建 demo6.js 文件, 代码如下:
var fs = require("fs");
var data = '测试写入数据';
// 创建一个可以写入的流,写入到文件 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 文件中。代码执行结果如下:
程序执行完毕
写入完成。
管道流
将一个流的数据插入到另外一个流中,创建 demo7.js 文件, 代码如下:
var fs = require("fs");
// 创建一个可读流
var readerStream = fs.createReadStream('mytext.txt');
// 创建一个可写流
var writerStream = fs.createWriteStream('output.txt');
// 管道读写操作
// 读取 input.txt 文件内容,并将内容写入到 output.txt 文件中
readerStream.pipe(writerStream);
console.log("程序执行完毕");
代码执行结果如下:
程序执行完毕
链式流
链式是通过连接输出流到另外一个流并创建多个流操作链的机制。链式流一般用于管道操作。
创建 compress.js 文件, 代码如下:
var fs = require("fs");
var zlib = require('zlib');
// 压缩 mytext.txt 文件为 mytext.txt.gz
fs.createReadStream('mytext.txt')
.pipe(zlib.createGzip())
.pipe(fs.createWriteStream('mytext.txt.gz'));
console.log("文件压缩完成。");
代码执行结果如下:
文件压缩完成。
网友评论