Node.js:fs文件系统模块
fs文件系统模块,这是一个非常重要的模块,对文件的操作都基于它。该模块的所有方法都有同步和异步两种方式,下面便介绍一下该模块的使用。
1、检测当前进程对文件的权限
使用fs.access(path[, mode], callback)方法检查权限,mode参数是一个整数,有以下常量值:
- fs.constants.F_OK path对调用进程是可见的,既存在
- fs.constants.R_OK path是可读的
- fs.constants.W_OK path是可写的
- fs.constants.X_OK path是可执行的
使用如下所示:
fs.access('./note.txt',fs.constants.F_OK,(err)=>{
console.log(err?'文件不存在':'文件已经存在');
});
同步版本,如果发生异常,则直接抛出异常,否则什么也不做。同步版本可以利用try..catch来做,适用所有方法,如下所示:
try{
fs.accessSync('./note.txt',fs.constants.F_OK);
}catch(ex){
console.log('文件不存在');
}
2、获取文件状态
使用fs.stat(path, callback),fs.statSync(path)方法来获取指定path的状性,callback有(err, stats)两个参数,stats是fs.stats对象,具有以下属性:
{ dev: 638212,
mode: 33206,
nlink: 1,
uid: 0,
gid: 0,
rdev: 0,
blksize: undefined,
ino: 105553116266564850,
size: 1094,
blocks: undefined,
atime: 2016-11-22T08:45:43.505Z,
mtime: 2016-11-22T09:33:13.535Z,
ctime: 2016-11-22T09:33:13.535Z,
birthtime: 2016-11-22T08:45:43.505Z }
还有以下方法:
stats.isFile()
stats.isDirectory()
stats.isBlockDevice()
stats.isCharacterDevice()
stats.isSymbolicLink() (only valid with fs.lstat())
stats.isFIFO()
stats.isSocket()
使用如下所示:
fs.stat('./app.js',(err,stats)=>{
if(err) throw err;
console.log(stats);
});
var stats = fs.statSync('../test.txt');//同步版本
3、文件追加
使用fs.appendFile(file, data[, options], callback)方法向file写入数据,如果file不存在,则创建file,data参数为字符串或buffer,options可选参数是对象或字符串,具有以下属性:
- encoding | default = 'utf8' 编码
- mode default = 0o666 打开模式
- flag default = 'a'
使用如下所示:
fs.appendFile('./test.txt','hello world!\r\n',(err)=>{
if(err) throw err;
console.log('写入成功');
});
//appendFile同步版本,返回值为undefined
fs.appendFileSync('./test.txt','hello nodejs!\r\n');
4、文件读取和写入
文件读取使用fs.readFile(file[, options], callback)方法,参数含义如下:
- file 文件名或文件描述符
- options 对象或字符串,如果是对象,则包含encoding和flag,前者默认为null,后者为'r'
- callback 参数为(err,data)
如果指定的文件不存在,则直接抛出错误。使用如下所示:
fs.readFile('./test4.txt',{encoding:'utf8',flag:'r'},(err,data)=>{
if(err) throw err;
console.log(data);
});
var data = fs.readFileSync('../test4.txt',{encoding:'utf8',flag:'r'});
文件写入数据,使用fs.writeFile(file, data[, options], callback)方法,参数含义如下:
- file 文件名或文件描述符
- data 字符串或buffer
- options 对象或字符串,如果是对象,则包含encoding、mode以及flag,依次默认为utf8,0o666,'w'
- callback 参数err
如果指定的文件不存在,则创建该文件,相反则替换原来的文件。使用如下所示:
var data = "hello node!";
fs.writeFile('./test1.txt',data,{flag:'w'},(err)=>{
if(err) throw err;
console.log('written ok.');
});
fs.writeFileSync('./test1.txt',data,{flag:'w'});
我们也可以利用fs的open,read,write,stat等方法来实现文件的读取和写入。
fs.open(path, flags[, mode], callback)方法打开一个文件获取句柄,flags参数有以下这些:
'r' - 以只读方式打开文件,若文件不存在则报错。
'r+' - 以读写方式打开文件,若文件不存在则报错。
'rs+' 在同步模式下,以读写方式打开文件
'w' - 以写方式打开文件,若文件不存在则创建
'wx' - 以写方式打开文件,若文件不存在则抛出异常.
'w+' - 以读写方式打开文件,若文件不存在则创建,相反则清空文件.
'wx+' - 以读写方式打开文件,若文件不存在则抛出异常.
'a' - 以追加方式打开文件,若文件不存则创建文件
'ax' - 以追加方式打开文件,若文件不存则抛出异常.
'a+' - 以追加和读方式打开文件,若文件不存则创建文件
'ax+' - 以追加和读方式打开文件,若文件不存则失败
callback回调函数有(err,fd)两个参数。
fs.read(fd, buffer, offset, length, position, callback)方法,从一个文件中读取数据存入buffer中,参数含义如下:buffer Buffer对象,用来存储读取的数据
offset buffer开始写的位置
length 需要读取的长度
position 指定从文件的哪个位置开始读取,若设置为null,则从文件当前位置开始读取
callback 有三个参数(err, bytesRead, buffer) bytesRead为实际读取字节数
fs.write(fd, buffer, offset, length[, position], callback)方法,将buffer数据写如指定文件中,参数含义如下:offset和length指定buffer的部分
position 指定文件的开始写入的文件,若不为数字则从文件当前位置开始写入
下面是一个使用open,write,read,stat方法实现的文件内容复制的函数,如下所示:
function copy(src, dest) {
const destFd = fs.openSync(dest, 'w+'),
srcStat = fs.statSync(src);
const buffer = new Buffer(srcStat.size);
console.log('复制开始...');
console.log(src+'大小:'+srcStat.size)
fs.open(src,'r',(err,fd)=>{
if(err) throw err;
fs.read(fd,buffer,0,srcStat.size,null,(err,bytesRead,buff)=>{
if(err) throw err;
console.log('实际读取大小:'+bytesRead);
fs.close(fd,()=>{});
fs.write(destFd,buff,0,bytesRead,null,(err, written, buffer)=>{
if(err) throw err;
console.log('已完成复制,向'+dest+'写入了'+written);
fs.close(destFd,()=>{});
});
});
});
}
copy('./app.js','./appbak.js');
执行结果如下:
E:\developmentdocument\nodejsdemo>node fs-examples.js
复制开始...
./app.js大小:1094
实际读取大小:1094
已完成复制,向./appbak.js写入了1094
5、文件重命名、删除
方法fs.rename(oldPath, newPath, callback)可以实现文件的重命名,还能实现文件的移动,如果oldPath与newPath在同一目录下,则是重命名,否则是移动文件并重命名,使用如下所示:
fs.rename('../test4.txt','./test4.txt',(err)=>{
if(err) throw err;
console.log('rename success.');
});
fs.renameSync('../test2.txt','../test4.txt');
文件删除需要用到fs.unlink(path, callback)方法,使用也很简单,如下所示:
fs.unlink('./dir/11.txt',(err)=>{
if(err) throw err;
console.log('delete file success.');
});
fs.unlinkSync('./dir/11.txt');
6、创建、读取、删除目录
创建目录使用的是fs.mkdir(path[, mode], callback)方法,mode参数默认为0o777,但是该方法只能创建一级目录,否则抛出异常,如下所示:
fs.mkdir('./a',0o777,(err)=>{
if(err) throw err;
console.log('mkdir success');
});
//mkdir的同步版本,返回值为undefined
fs.mkdirSync('./test',0o777);
为了能够创建多级目录,可以自己定义一个函数来实现,需要用到path模块的dirname方法,如下所示:
function isFileExists(filePath){
var bool = !0;
try{
fs.accessSync(filePath,fs.F_OK);
}catch(err){
bool = !1;
}
return bool;
}
function mkdirp(dirpath,mode,cb){
if(isFileExists(dirpath)){
cb(dirpath);
}else{
mkdirp(path.dirname(dirpath),mode,function(){
fs.mkdir(dirpath,mode,cb);
});
}
}
扫描目录需要用到fs.readdir(path[, options], callback)方法,options参数为字符串或对象,callback回调函数有(err, files)两个参数,files是一个文件名数组,该方法也是只能扫描一级目录,使用如下所示:
fs.readdir('./',(err,files)=>{
if(err) throw err;
console.log(files);
});
如果要实现可以递归扫描目录,可以自己定义一个函数,如下所示:
function scandir(dirpath){
var filesArr = {};
if(!isFileExists(dirpath)) return !1;
function scan(filepath){
var statObj = fs.statSync(filepath);
if(!statObj.isDirectory()) return filesArr.push(filepath);
var files = fs.readdirSync(filepath);
files.forEach((file,idx,arr)=>{
scan(filepath+'/'+file);
});
}
scan(dirpath);
return filesArr;
}
删除目录使用fs.rmdir(path, callback)方法,只能删除一级目录且目录须为空,使用如下所示:
fs.rmdir('./dir',(err)=>{
if(err) throw err;
console.log('delete dir success.');
});
要实现类似rm -rf的递归删除效果,可以使用如下代码:
function deldirs(dirpath){
var stat = null,
emptyFoldersArr = [];
function scan(spath){
var files = fs.readdirSync(spath);
emptyFoldersArr.push(spath);
if(files.length>0){
files.forEach((file,idx,arr)=>{
if(fs.statSync(spath+'/'+file).isDirectory()){
scan(spath+'/'+file);
}else{
return fs.unlinkSync(spath+'/'+file),!0;
}
});
}
}
scan(dirpath);
for(var l=emptyFoldersArr.length-1,i=l;i>=0;i--){
fs.rmdirSync(emptyFoldersArr[i]);
}
}
7、获取路径的绝对路径
使用fs.realpath(path[, options], callback)方法可以获取path的绝对路径,callback有(err, resolvedPath)两个参数,使用如下所示:
fs.realpath('./test.txt',(err,resolvePath)=>{
if(err) throw err;
console.log(resolvePath);
});
console.log(fs.realpathSync('./test.txt'));
执行结果如下所示:
E:\developmentdocument\nodejsdemo>node fs-examples.js
E:\developmentdocument\nodejsdemo\test.txt
Node.js:fs文件系统模块的更多相关文章
- Node.js fs文件系统模块
一.读取文件几个步骤 1.先引入fs文件系统模块 2.使用readfile 或 readFileSync 注意点:它们的回调函数有两个参数,第一个是err,第二个是data,得到的data是buffe ...
- node.js中fs文件系统模块的使用
node.js中为我们提供了fs文件系统模块,实现对文件或目录的创建,修改和删除等操作. fs模块中,所有的方法分为同步和异步两种实现. 有 sync 后缀的方法为同步方法,没有 sync 后缀的方法 ...
- Node.js——fs模块(文件系统),创建、删除目录(文件),读取写入文件流
/* 1. fs.stat 检测是文件还是目录(目录 文件是否存在) 2. fs.mkdir 创建目录 (创建之前先判断是否存在) 3. fs.writeFile 写入文件(文件不存在就创建,但不能创 ...
- Node.js学习——基本模块之fs
基本模块之fs 异步读文件 异步读取一个文本文件的代码如下: 'use strict'; var fs = require('fs'); fs.readFile('sample.txt', 'utf- ...
- 从官网学习Node.js FS模块方法速查
最新文档请查看仓库 https://github.com/wangduandu... 1. File System 所有文件操作提供同步和异步的两种方式,本笔记只记录异步的API 异步方式其最后一个参 ...
- Node.js FS模块方法速查
1. File System 所有文件操作提供同步和异步的两种方式,本笔记只记录异步的API 异步方式其最后一个参数是回调函数.回调函数的第一个参数往往是错误对象,如果没有发生参数,那么第一个参数可能 ...
- Node.js入门:模块机制
CommonJS规范 早在Netscape诞生不久后,JavaScript就一直在探索本地编程的路,Rhino是其代表产物.无奈那时服务端JavaScript走的路均是参考众多服务器端语言来 ...
- Node.js的Formidable模块的使用
今天总结了下Node.js的Formidable模块的使用,下面做一些简要的说明. 1) 创建Formidable.IncomingForm对象 var form = new formidab ...
- node.js fs.open 和 fs.write 读取文件和改写文件
Node.js的文件系统的Api //公共引用 var fs = require('fs'), path = require('path'); 1.读取文件readFile函数 //readFile( ...
随机推荐
- 关于如何提高Web服务端并发效率的异步编程技术
最近我研究技术的一个重点是java的多线程开发,在我早期学习java的时候,很多书上把java的多线程开发标榜为简单易用,这个简单易用是以C语言作为参照的,不过我也没有使用过C语言开发过多线程,我只知 ...
- 使用ubuntu作为web开发环境的一些感受
从ms-dos,win95,win98,winMe,winXp,vista,win7,win10我都有使用的经历,我使用时间最长的应属winxp,其次是win7,说实话,我觉得这两个系统是微软做的最好 ...
- 【NLP】十分钟快览自然语言处理学习总结
十分钟学习自然语言处理概述 作者:白宁超 2016年9月23日00:24:12 摘要:近来自然语言处理行业发展朝气蓬勃,市场应用广泛.笔者学习以来写了不少文章,文章深度层次不一,今天因为某种需要,将文 ...
- 代码的坏味道(14)——重复代码(Duplicate Code)
坏味道--重复代码(Duplicate Code) 重复代码堪称为代码坏味道之首.消除重复代码总是有利无害的. 特征 两个代码片段看上去几乎一样. 问题原因 重复代码通常发生在多个程序员同时在同一程序 ...
- 【Linux大系】Linux的概念与体系
感谢原作者:Vamei 出处:http://www.cnblogs.com/vamei 我在这一系列文章中阐述Linux的基 本概念.Linux操作系统继承自UNIX.一个操作系统是一套控制和使用计算 ...
- Android:Activity+Fragment及它们之间的数据交换.
Android:Activity+Fragment及它们之间的数据交换 关于Fragment与Fragment.Activity通信的四种方式 比较好一点的Activity+Fragment及它们之间 ...
- Android种使用Notification实现通知管理以及自定义通知栏(Notification示例四)
示例一:实现通知栏管理 当针对相同类型的事件多次发出通知,作为开发者,应该避免使用全新的通知,这时就应该考虑更新之前通知栏的一些值来达到提醒用户的目的.例如我们手机的短信系统,当不断有新消息传来时,我 ...
- WINDOWS系统下MYSQL安装过程中的注意事项
1.首先MySQL的安装方式有两种:一种是MSI安装方式,很简单就像安装Windows软件一样.另外一种就是ZIP安装方式.这种相对而言比较麻烦.新手推荐MSI安装方式. 安装方式有以下两种: MSI ...
- windows 7(32/64位)GHO安装指南(序篇)~
大家好,本人是高三刚毕业,即将踏入校园的程序猿~我写这篇文章呢,主要是想巩固一下之前对于电脑的基础知识理论,也希望能帮助没有电脑基础的同学能维护一下自己的电脑,要是能帮助女生修电脑那就是更好啦~~哈哈 ...
- Linux设备文件简介(转载)
Linux 中的设备有2种类型:字符设备(无缓冲且只能顺序存取).块设备(有缓冲且可以随机存取).每个字符设备和块设备都必须有主.次设备号,主设备号相同的设 备是同类设备(使用同一个驱动程序).这些设 ...