当前位置: 首页 > news >正文

fs 流

用流的方式 去读取的好处,可以处理中间的过程

let ws=fs.createWriteStream('文件的path’) //创建一个写入流
ws.write(‘内容’,“utf-8”)

eg:
你要先准备一个文件
var rs=fs.createReadStream(’./文件名‘);
var body="";
rs.on (‘data’,(thunk)=>{//读取一段内容
body+=thunk
})
rs.on(‘end’,()=>{ //end 事件表示读取完毕
console.log(body)
})

on代表的是监听事件
data是事件

原始:
EventEmitter:事件触发器

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

// 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 写入文件
// 创建一个可以写入的流,写入到文件 package1.json 中
let writerStream = fs.createWriteStream(’./package1.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(“程序执行完毕”);
}

简化:
管道流:
管道提供了一个输出流到输入流的机制。通常我们用于从一个流中获取数据并将数据传递到另外一个流中。
在这里插入图片描述
我们把文件比作装水的桶,而水就是文件里的内容,我们用一根管子(pipe)连接两个桶使得水从一个
桶流入另一个桶,这样就慢慢的实现了大文件的复制过程。
以下实例我们通过读取一个文件内容并将内容写入到另外一个文件中。

let fs = require(‘fs’);

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

相关文章:

  • Autohotkey读写ini文件内容
  • 静态资源托管
  • 难道.NET Core到R2连中文编码都不支持吗?
  • 前端和后端接口的实现简述
  • DCloud与APICloud的对比
  • nodejs --路由 router
  • 栈的应用——迷宫问题
  • 使用sass的安装使用
  • Linux_Rsync远程同步备份服务器
  • 思索好久要不要写这个react ,还是写了
  • 操作系统原理(转)
  • webpack静态模块打包器,一般不知道但是就打包了
  • linux下安装图片识别环境
  • 回顾:C++开篇课堂
  • react 脚手架环境安装以及实现过程
  • 0基础学习移动端适配
  • Apache的基本使用
  • canvas绘制圆角头像
  • ES10 特性的完整指南
  • IDEA 插件开发入门教程
  • java B2B2C 源码多租户电子商城系统-Kafka基本使用介绍
  • MySQL QA
  • Rancher-k8s加速安装文档
  • sessionStorage和localStorage
  • uva 10370 Above Average
  • VirtualBox 安装过程中出现 Running VMs found 错误的解决过程
  • 从setTimeout-setInterval看JS线程
  • 从零搭建Koa2 Server
  • 利用DataURL技术在网页上显示图片
  • 如何设计一个比特币钱包服务
  • 使用common-codec进行md5加密
  • 我看到的前端
  • 在GitHub多个账号上使用不同的SSH的配置方法
  • 正则表达式小结
  • Java总结 - String - 这篇请使劲喷我
  • TPG领衔财团投资轻奢珠宝品牌APM Monaco
  • 带你开发类似Pokemon Go的AR游戏
  • 如何用纯 CSS 创作一个货车 loader
  • #NOIP 2014#day.2 T1 无限网络发射器选址
  • (04)odoo视图操作
  • (1/2) 为了理解 UWP 的启动流程,我从零开始创建了一个 UWP 程序
  • (1综述)从零开始的嵌入式图像图像处理(PI+QT+OpenCV)实战演练
  • (AtCoder Beginner Contest 340) -- F - S = 1 -- 题解
  • (pojstep1.3.1)1017(构造法模拟)
  • (solr系列:一)使用tomcat部署solr服务
  • (阿里巴巴 dubbo,有数据库,可执行 )dubbo zookeeper spring demo
  • (附源码)springboot太原学院贫困生申请管理系统 毕业设计 101517
  • (附源码)ssm跨平台教学系统 毕业设计 280843
  • (附源码)ssm智慧社区管理系统 毕业设计 101635
  • (论文阅读22/100)Learning a Deep Compact Image Representation for Visual Tracking
  • (十八)devops持续集成开发——使用docker安装部署jenkins流水线服务
  • (一)python发送HTTP 请求的两种方式(get和post )
  • (一)Thymeleaf用法——Thymeleaf简介
  • (转)母版页和相对路径
  • .NET Core6.0 MVC+layui+SqlSugar 简单增删改查