1、表达式

在命令行输入  node回车后,可以在后边输入相应的表达式,进行运算操作
 

2、阻塞文件读取

var data=fs.readFileSync('input.txt', 'utf-8');
 

3、非阻塞文件读取

fs.readFile('input.txt',function(err,data){
if(err){
console.log(err);
}else{
console.log(data.toString());
}
});
 

4、将文件写入缓冲区

var buf=new Buffer('伍姣龙', 'utf-8');//一个汉子在 utf-8下占3个字节
console.log(buf.length);//9
console.log(buf.toString());//伍姣龙
console.log(buf.toJSON(buf));//[ 228, 188, 141, 229, 167, 163, 233, 190, 153 ]
5、事件驱动【关键字:eventEmitter.on('事件名',function(){})| eventEmitter.emit('事件名') 】
  1. var events=require('events');
  2. //实例化EventLitter对象
  3. var eventEmitter=new events.EventEmitter();
  4. eventEmitter.addListener('connection',function(){
  5. console.log('连接陈宫2!');
  6. });
  7. eventEmitter.addListener('connection',function(){
  8. console.log('连接陈宫3');
  9. });
  10. eventEmitter.on('connection',function(){
  11. console.log('连接成功1');
  12. //触发 data_received
  13. eventEmitter.emit('data_received');
  14. });
  15. eventEmitter.on('data_received',function(){
  16. console.log('数据接收成功');
  17. });
  18. //触发事件
  19. eventEmitter.emit('connection');
  20. console.log('程序执行完毕');
6、文件流
【读取流】 四大事件  data   end  error  finish【用在写入的时候】
  1. var fs=require('fs');
  2. var zlib=require('zlib');//文件解压缩模块
  3. var read=function(){
  4. var data='';
  5. var readerStream=fs.createReadStream('input.txt','utf-8');
  6. //当有数据时触发
  7. readerStream.on('data',function(chunk){
  8. console.log('正在读取数据');
  9. data+=chunk;
  10. });
  11. //文件没有更多数据时候触发
  12. readerStream.on('end',function(){
  13. console.log('数据读取完毕:'+data);
  14. });
  15. //在接受和写入过程出错时触发
  16. readerStream.on('error',function(err){
  17. console.log(err.stack);
  18. });
  19. }
【写入流】会创建一个output.txt文件
  1. var write=function(){
  2. //创建写入流
  3. var writeStream=fs.createWriteStream('output.txt');
  4. var data='我是一个好孩子';
  5. writeStream.write(data,'utf-8');
  6. writeStream.end();
  7. writeStream.on('finish',function(){
  8. console.log('写入完成');
  9. });
  10. writeStream.on('error',function(err){
  11. console.log(err.stack);
  12. });
  13. console.log('程序执行完成');
  14. }
【管道流】 从一个流中读取然后写到另一个输出流
  1. var gdStream=function(){
  2. var readerStream=fs.createReadStream('input.txt');
  3. var writeStream=fs.createWriteStream('output.txt');
  4. readerStream.pipe(writeStream);
  5. console.log('程序执行完成');
  6. }
【链式流】文件解压缩操作
  1. /链式流创建压缩文件
  2. var gZipStream=function(){
  3. //var fs=require('fs');
  4. fs.createReadStream('input.txt').pipe(zlib.createGzip()).pipe(fs.createWriteStream('input.txt.gz'));
  5. }
  6. //gZipStream();
  7. //解压文件
  8. var gunZip=function(){
  9. fs.createReadStream('input.txt.gz').pipe(zlib.createGunzip()).pipe(fs.createWriteStream('input2.txt'));
  10. }
  11. gunZip();
7、简单服务器创建并设置请求头
  1. var http=require('http');
  2. var server=http.createServer(function(req,res){
  3. var body='hello word';
  4. res.setHeader('Content-Length',body.length);
  5. res.setHeader('Content-Type','text/plain');
  6. res.statusCode=302;
  7. res.end(body);
  8. });
  9. server.listen(3000);
 
 
 

1-2 nodejs小节 文件读取的更多相关文章

  1. NodeJS文件读取:感恩常在--抓把糖果,愉悦客人

    通过上一篇文章“NodeJS服务器:一行代码 = 一个的HTTP服务器”,我们已经开启了NodeJS之旅,开发了一个监听在8000端口的HTTP服务器,虽然功能很简单,但是,已经让我们感受到用Node ...

  2. NodeJs之文件上传

    NodeJs之文件上传 一,介绍与需求 1.1,介绍 1,multer模块 multer用于处理文件上传的nodejs中间件,主要跟express框架搭配使用,只支持表单MIME编码为multipar ...

  3. NodeJS遍历文件生产文件列表

    本文实例讲述了NodeJS遍历文件生产文件列表功能.分享给大家供大家参考,具体如下: 功能需求:在工作中我们可能经常需要知道项目中静态文件列表发布,一个一个去检索写,那就太苦逼了. 要想知道里面的文件 ...

  4. 使用 nodejs 对文件进行批量重命名

    0. 前言 从B站下载了一点视频,硕鼠自动将标题添加到了每个文件名的前面,导致文件名过长,不方面查看文件的具体内容. 虽然只有二十几个文件,但是手动删除前缀还是个不小的工作量,还有可能删除错误.考虑到 ...

  5. java中的文件读取和文件写出:如何从一个文件中获取内容以及如何向一个文件中写入内容

    import java.io.BufferedReader; import java.io.BufferedWriter; import java.io.File; import java.io.Fi ...

  6. php xml 文件读取 XMLReader

    php xml 文件读取 <?php /** $xmlString = '<xml> <persons count="10"> <person ...

  7. 详解Js中文件读取机制

    前言,文件读取是提高应用体验度的必须接口,应用场景中需求很频繁. Js处理文件读取,由于处于安全方面的考虑,在2000年以前,都是以“<input type="file"&g ...

  8. C# 文件操作 把文件读取到字节数组

    string zipfile = "c:\\a.zip"; //方法1 FileStream fs = new FileStream(zipfile, FileMode.Open) ...

  9. H5学习系列之文件读取API--本文转自http://blog.csdn.net/jackfrued/article/details/8967667

    HTML5定义了FileReader作为文件API的重要成员用于读取文件,根据W3C的定义,FileReader接口提供了读取文件的方法和包含读取结果的事件模型. FileReader的使用方式非常简 ...

随机推荐

  1. Sql Server系列:数据控制语句

    数据控制语句用来设置.更改用户或角色的权限,包括GRANT.DENY.REVOKE等语句. GRANT用来对用户授予权限,REVOKE可用于删除已授权的权限,DENY用于防止主体通过GRANT获得特定 ...

  2. 数据结构与算法JavaScript (四) 串(BF)

    串是由零个或多个字符组成的有限序列,又叫做字符串 串的逻辑结构和线性表很相似的,不同的是串针对是是字符集,所以在操作上与线性表还是有很大区别的.线性表更关注的是单个元素的操作CURD,串则是关注查找子 ...

  3. 【转】C#语言之“string格式的日期时间字符串转为DateTime类型”的方法

    方法一:Convert.ToDateTime(string) string格式有要求,必须是yyyy-MM-dd hh:mm:ss ================================== ...

  4. 前端学PHP之数据类型

    × 目录 [1]总括 [2]布尔型 [3]整型[4]浮点型[5]字符串[6]数组[7]对象[8]NULL[9]资源 前面的话 同javascript一样,php也是一门弱类型语言,或者说成类型松散的语 ...

  5. 应用程序框架实战二十一:DDD分层架构之仓储(介绍篇)

    前面已经介绍过Entity Framework的工作单元和映射层超类型的封装,从本文开始,将逐步介绍仓储以及对查询的扩展支持. 什么是仓储 仓储表示聚合的集合. 仓储所表现出来的集合外观,仅仅是一种模 ...

  6. 浅析inline-block--使用inline-block创建布局

    inline-block前端程序猿们肯定不陌生,它是display属性的一个取值. 之所以称之为inline-block.是因为它兼具行内元素(inline-element)和块级元素(block-e ...

  7. weight属性你用的真的6嘛?

    相信大家在日常开发中一定使用过weight这个属性,它的作用一个是权重,另一个就是渲染优先级,但是你真的能很6的使用它嘛?如果不是,那么请继续往下看!!! 我们知道,当weight起到不同作用的时候, ...

  8. 走进vue.js(一)

    走进vue.js(一) vue.js作为目前最具前景的前端框架之一,既然如此,博主贯彻以往的作风,肯定要捣鼓一番,经过为期半个多月的研究,算是对vue有了深刻的理解与认识,下面分三个章节解开vue.j ...

  9. RAC 10.2.0.5,客户端登陆间断遭遇ORA-12545

    实验环境: 服务端:OEL 5.7 + Oracle 10.2.0.5 RAC  客户端:Windows 7 + Oracle 11.2.0.1 Client   1.客户端登陆间断遭遇ORA-125 ...

  10. 前端开发编辑器(notepad++、sublime text)

    1.Notepad++ 正则替换: 如<td>第三节</td> 替换成<td><input type="text" value=" ...