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();

// 处理流事件 --> 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

文件解压完成。

流线动态图python_Node.js Stream(流)相关推荐

  1. 流线动态图python_流的解释|流的意思|汉典“流”字的基本解释

    详细字义 ◎ 流 liú 〈动〉 (1) (会意.本义:水流动) (2) 同本义 [flow] 观其流泉.--<诗·大雅·公刘> 顄淡滂流.--<文选·马融·长笛赋> 血流殷地 ...

  2. Node.js Stream(流) 简单易懂全解析

    一.node.js中的流是什么 stream(流)是Node.js提供的又一个仅在服务区端可用的模块,流是一种抽象的数据结构.Stream 是一个抽象接口,Node 中有很多对象实现了这个接口.例如, ...

  3. node.js Stream(流) 和 EJS 模板引擎——0822

    一.node.js 中的 Stream(流) 1.什么是 Stream ? Stream 是一个抽象接口,Node 中有很多对象实现了这个接口.例如,对http服务器发起请求的request 对象就是 ...

  4. 使用通用mapper实现条件查询_【微服务】152:Stream流和通用mapper批量查询的使用...

    今天是刘小爱自学Java的第152天. 感谢你的观看,谢谢你. 学习计划安排如下: 补充完昨天商品查询中关于分类和品牌的部分,其中牵扯到了两个非常重要的知识点: Stream流的使用,这个学过后基本就 ...

  5. JS——瀑布流无限加载以及动态生成a标签

    如何实现瀑布流排列效果?看下面这张图 通过js去比较每张图片的高度,然后进行排列. 这是一个模拟的瀑布流的list列表项 <div id="main"><div ...

  6. Node.js: 认识流stream

    流是Node.js中一个非常重要的概念, 也是Node.js之所以适用于I/O密集型场景的重要原因之一. 流是Node.js移动数据的方式,流可以是可读的和/或可写的.在Node.js中很多模块都使用 ...

  7. JS生成gif动态图下载

    需求:通过动态变化的图生成一个gif图提供下载. 实现方案: 1.可通过服务端生成对应gif,然后前端请求下载 2.前端自己实现生成gif图片,自行下载 采用方案: 前端实现方式,于是在网上找各种相关 ...

  8. 惊艳!可视化的 js:动态图演示 - 事件循环 Event Loop

    原文地址:https://dev.to/lydiahallie/javascript-visualized-event-loop-3dif 原文作者:Lydia Hallie 译者:夜尽天明 译者博客 ...

  9. 把鼠标放到图片后,(HTML+JS实现)静态图片变成动态图

    前几天有个朋友问我这个问题:如何实现"把鼠标放到图片后,变成动态图",他估计是没学过JavaScript,其实这个问题实现起来还是挺简单的.下面简单说下: 原图片放静态图,为图片设 ...

最新文章

  1. 三十四、深入Java中的泛型(上篇)
  2. 【转】CT中的“层“与“排“的区别
  3. 表格状态列_不用软件也能做好多个项目跟进管理?我用一个协同表格就搞定
  4. 启动瑞星杀毒时提示"应用程序正常初始化(0xc00000ba)失败
  5. 关闭 php opcache
  6. 为什么预估执行计划与真实执行计划会有差异?
  7. 《java入门第一季》之java语法部分小案例
  8. 西南交通大学计算机组成原理,西南交通大学计算机组成原理课程设计报告
  9. ​50 年来最具影响力的十大编程语言!
  10. Vuejs 使用 lib 库模式打包 umd 解决 NPM 包发布的问题
  11. 压力测试的轻量级具体做法
  12. php色子,jQuery+PHP实现的掷色子抽奖游戏实例,jquery色子_PHP教程
  13. 域客户统一关闭UAC
  14. linux下的stl文档,Linux_Instl_HardDisk
  15. 《实变函数简明教程》,P63,可测集上的连续函数一定可测
  16. 安卓机自动肝手游脚本
  17. 算法为啥子那么难【转】
  18. 拒绝纷繁复杂 快速制表软件分享
  19. 亥姆霍兹线圈分类简介
  20. python中的时间处理模块(二):datetime模块之timedelta类详解

热门文章

  1. Hadoop:简单介绍
  2. python程序填空题参照代码模板、完善代码_python二级考试操作题11.pdf
  3. MacOS使用brew无法安装Python_无法安装gdbm_无法安装autojump
  4. predicate 列存储索引扫描_ColumnStore index (列存储索引)解析
  5. Ubuntu下如何正确安装FFmpeg
  6. 图解python pdf_Python合并同一个文件夹下所有PDF文件的方法
  7. java怎么兼容switch_java – Switch语句给出了不兼容类型错误
  8. java 方式配置ssm,关于SSM以及Spring boot中对于Spring MVC配置的问题
  9. python调用opengl_Python运行OpenGL示例
  10. aop+注解 实现对实体类的字段校验_SpringBoot实现通用的接口参数校验