Node.js之操作文件系统(一)
Node.js之操作文件系统(一)
1. 同步方法与异步方法
在Node.js中,使用fs模块来实现所有有关文件及目录的创建、写入及删除操作。,在fs模块中,所有对文件及目录的操作都可以使用同步与异步这两种方法。这两者区别是:同步方法立即返回操作结果,在使用同步方法执行的操作结束之前,不能执行后续代码,代码类似如下:
Var fs = require('fs')
var data = fs.readFileSysnc('./index.html','utf8')
//等待操作返回结果,然后利用该结果
console.log(data)
而异步方法将操作结果作为回调函数的参数进行返回,在方法调用之后,可以立即执行后续代码,代码如下:
var fs = require('fs')
fs.readFile('./index.html','utf8'.function(err,data){
//操作结果作为回调函数的第二个参数返回
console.log(data)
})
另外,当使用如下所示的方法调用多个异步方法时,并不能确保操作结果的返回顺序
fs.readFile('./file.html',function(err,data){
//回调函数代码
})
fs.readFile('./otrher.html',function(err,data){
//回调函数代码
})
在上述代码中,我们同时执行两个文件的读取操作,但是并不确保哪个操作结果先辈返回。如果要确保在一个问价读取完毕后再读取两一个文件,我们应使用如下方法:
fs.readFileSync('./file.html',function(err,data){
//回调函数代码
})
fs.readFileSync('./otrher.html',function(err,data){
//回调函数代码
})
2. 对文件执行读写操作
2.1 文件的完整读写
可以使用readFile方法或者readFileSync方法完整读取一个文件:
fs.readFile(filename,[options],callback)
//第一个参数:必选指定读取文件的完整文件路径及文件名
第二个参数:指定读取文件时需要使用的选项,在该参数值对象中可以使用flag属性指定对该文件采取什么操作,默认为‘r’
option:
flag'r':读取文件,如果文件不存在则抛出异常
'r+':读取并写入文件,如果文件不存在则抛出异常
'rs':以同步方式读取文件并通知操作系统忽略本地文件系统缓存,如果文件不存在则抛出异常。因为本属性值忽略本地缓存,适用于操作网络文件系统,但由于其对性能产生一定的负面影响,不建议在其他环境下使用
'w':写入文件,如果文件不存在则创建文件,如果文件存在则清空文件内容
'wx':作用与'w'类似,但以排他方式写入文件
'w+':读取并写入文件。如果不存在则创建文件,如果该文件已存在则清空文件内容
'wx+':作用与'w+'类似,但是以排他方式写入文件
'a':追加写入文件,如果文件不存在则创建文件
'ax':作用与'a+'类似,但是以排他方式打开文件
encoding:
utf8,ascii,base64,
callback(err,data){
//回调函数代码略
}
//第一个参数为读取文件操作失败时触发的错误对象
第二个参数值为读取到的文件内容
在使用同步方法读取文件时,使用readFileSync方法:
var data = fs.readFileSync(filename,[options])
eg:
var fs = require('fs')
try{
var data = fs.readFileSync('./text.txt','utf8')
//在控制台中输出文件内容
console.log(data)
}catch(ex){
console.log('读取文件时发生错误')
}
在完整写入一个文件时,利用fs模块中的writeFile方法或者writeFileSync方法
fs.writeFile(filename,datda,[options],callback)
//第一个参数:用于指定被写入文件的完整文件路径及文件名
第二个参数:用于指定需要写入的内容,参会素可以为一个字符串或一个Buffer对象
第三个参数:指定写入文件时需要的选项
flag属性:用于指定该文件采用何种操作,默认为'w'
mode属性:指定当文件被打开时对文件的读写权限,默认为0666(可读写),第一位必须为0,第二位用于规定文件或目录所有者的权限,第三位为文件或目录所属用户组的权限,第四位为其他用户权限
1:执行权限
2:写权限
4:读权限
encoding属性:指定使用何种编码格式来写入文件,:utf8 ascii base64
callback(err){
//回调函数代码
}
在使用同步方式写入文件时,使用writeFileSync方法:
fs.writeFileSync(filename,data,[options])
在将一个字符串或一个缓存区中的数据追加到一个文件底部时,可使用fs模块中的appendFile或者appendFildSync方法
fs.appendFile(filname,data,[options],callback)
fs.appendFileSync(filename,data[options])
2.2 从指定位置处开始读写文件
首先需要使用fs模块中的open方法或者openSync方法打开文件,
fs.open(filename,flags,[mode],callback)
其中callback参数为:function(err,fd){
//回调函数代码
}
//第一个参数为打开文件操作失败时所触发的错误对象,
第二个参数为一个整数值,代表打开文件时返回的文件描述符
使用同步方式打开文件时,使用openSync方法:
var fd = fs.openSync(filename,flag,[mode])
在打开文件之后,可以在回调函数中使用fs模块中的read方法或者readSync方法从文件的指定位置处读取文件,也可以使用fs模块中的write方法或者writeSync方法从文件的指定处开始写入数据
首先介绍read方法:
fs.read(fd,buffer,offset,length,position,callback)
//第一个参数:open方法所所使用的回调函数中返回的文件描述符或openSync方法返回的文件描述符;
第二个参数:英语指定将文件数据读取到哪个缓存区;
第三个参数:整数,用于指定向缓存区中写入数据时的开始位置,以字节为单位
第四个参数:整数,指定从文件中读取的字节数
第五个参数:整数,指定读取文件时开始位置
callback(err,bytesRead,buffer){
//回调函数代码
}
err:读取文件操作失败时触发的错误对象
bytesRead实际读取的字节数
buffer:被读取的缓存区对象
使用同步方式打开文件时,使用readSync方法:
var byteRead = fs.readSync(fd,buffer,offset,length,position)
在打开文件后,使用fs模块中的write方法或者writeSync方法从一个缓存区中读取数据并且从文件的指定处开始吸入这些数据
fs.write(fd,buffer,offset,length,position,callback)
其中callback为function(err,written,buffer){
//回调函数代码
}
eg:
1 var fs = require('fs')
2 var buf = new Buffer('我喜欢编程')
3 fs.open('./message.txt','w',function(err,fd){
4 fs.write(fd,buf,3,9,0,function(err,written,buffer){
5 if(err)console.log("写文件操作失败")
6 console.log("写文件操作成功")
7 })
8 })
在使用同步方式写入文件时,使用writeSync 方法
fs.writeSync(fd,buffer,offset,length,position)
在fs模块中,使用close方法与closeSync方法以关闭文件
fs.close(fd,[callbcak])
fs.closeSync(fd)
调用close方法前,可以利用fsyn方法将缓存区内容全部写入文件,防止出现遗漏数据
fs.fsyn(fd,[callback])
Node.js之操作文件系统(一)的更多相关文章
- Node.js之操作文件系统(二)
Node.js之操作文件系统(二) 1.创建与读取目录 1.1 创建目录 在fs模块中,可以使用mkdir方法创建目录,该方法的使用方法如下: fs.mkdir(path,[mode],callbca ...
- 在Node.js中操作文件系统(一)
在Node.js中操作文件系统 在Node.js中,使用fs模块来实现所有有关文件及目录的创建,写入及删除操作.在fs模块中,所有对文件及目录的操作都可以使用同步与异步这两种方法.比如在执行读文件操作 ...
- Node.js权威指南 (6) - 在Node.js中操作文件系统
6.1 同步方法与异步方法 / 856.2 对文件执行读写操作 / 86 6.2.1 文件的完整读写 / 86 6.2.2 从指定位置处开始读写文件 / 916.3 创建与读取目录 / 97 6.3. ...
- node.js高效操作mongodb
node.js高效操作mongodb Mongoose库简而言之就是在node环境中操作MongoDB数据库的一种便捷的封装,一种对象模型工具,类似ORM,Mongoose将数据库中的数据转换为Jav ...
- Node.js文件操作二
前面的博客 Node.js文件操作一中主要是对文件的读写操作,其实还有文件这块还有一些其他操作. 一.验证文件path是否正确(系统是如下定义的) fs.exists = function(path, ...
- mongoose - 让node.js高效操作mongodb
Mongoose库简而言之就是在node环境中操作MongoDB数据库的一种便捷的封装,一种对象模型工具,类似ORM,Mongoose将数据库中的数据转换为JavaScript对象以供你在应用中使用. ...
- node.js中fs文件系统模块的使用
node.js中为我们提供了fs文件系统模块,实现对文件或目录的创建,修改和删除等操作. fs模块中,所有的方法分为同步和异步两种实现. 有 sync 后缀的方法为同步方法,没有 sync 后缀的方法 ...
- MONGOOSE – 让NODE.JS高效操作MONGODB(转载)
Mongoose库简而言之就是在node环境中操作MongoDB数据库的一种便捷的封装,一种对象模型工具,类似ORM,Mongoose将数据库中的数据转换为JavaScript对象以供你在应用中使用. ...
- node基础学习——操作文件系统fs
操作文件系统fs 1.在Node.js中,使用fs模块来实现所有有关文件及目录的创建.写入及删除.在fs模块中,所有对文件及目录的操作都可以使用同步与异步两种方法,具有Sync后缀的方法均为同步方法. ...
随机推荐
- PCI_Making Recommendations
协作性过滤 简单理解从众多用户中先搜索出与目标用户'品味'相似的部分人,然后考察这部分人的偏爱,根据偏爱结果为用户做推荐.这个过程也成为基于用户的协作性过滤(user_based collaborat ...
- vue 自定义组件
1.Vue.component('component-test', { props:{}, data:function(){ return{} }, mounted:function(){}, com ...
- 以Random Forests和AdaBoost为例介绍下bagging和boosting方法
我们学过决策树.朴素贝叶斯.SVM.K近邻等分类器算法,他们各有优缺点:自然的,我们可以将这些分类器组合起来成为一个性能更好的分类器,这种组合结果被称为 集成方法 (ensemble method)或 ...
- selenium3.x 踏坑记
Selenium 3.x 出来也有段时间了,有哪些坑呢? 有好长一段时间没有用selenium了.最近想用来做个web自动化的小工具.根据以往经验,firefox是不需要下载driver的.启动fir ...
- (转)sql union和union all的用法及效率
1 熟悉union的相关操作 UNION指令的目的是将两个SQL语句的结果合并起来.从这个角度来看, 我们会产生这样的感觉,UNION跟JOIN似乎有些许类似,因为这两个指令都可以由多个表格中撷取资料 ...
- block的各种定义
1.作为变量 //block 的申明,定义,调用,block快捷方式inline //<#returnType#>(^<#blockName#>)(<#parameter ...
- 基于.NET CORE微服务框架 -谈谈Cache中间件和缓存降级
1.前言 surging受到不少.net同学的青睐,也提了不少问题,提的最多的是什么时候集成API 网关,在这里回答大家最近已经开始着手研发,应该在1,2个月内会有个初版API网关,其它像Token身 ...
- Angularjs跳转切换至对应选项卡
//跳转前页面 <div class="list user_order" ng-click="userOpen('userOrder',0)"> & ...
- dubbo-zookeeper(续)
本篇为继上一篇的续篇,主要内容分为以下几点: 1.zookeeper集群 2.web管理平台 3.dubbo配置说明 接下来我们开始继续吧. 一.zookeeper集群 顾名思义也就是多台zookee ...
- 13. leetcode 453. Minimum Moves to Equal Array Elements
Given a non-empty integer array of size n, find the minimum number of moves required to make all arr ...