nodejs中文件操作案例演示
/*
node中的异步操作
1、文件操作
2、网络操作
浏览器中的异步操作:
1、定时任务
2、时间处理
3、Ajax回调处理
*/
let fs = require('fs');
let path = require('path');
//文件系统,
/*
1、文件的获取操作
异步操作:
回调函数的第一个参数为错误对象,如果err为null,表示没有错误,否则表示报错了
第二个参数为一个对象,最常用的为两个方法:
isFile() 判断路径上是否是文件
isDirectory() 判断路径上是否是目录
*/
fs.stat('./test.js',(err,stat)=>{
if(stat.isFile()){
console.log('文件');
}else if(stat.isDirectory()){
console.log('目录');
}
});
/*
stat.atime:访问时间
stat.mtime:文件的数据发生变化的时间
stat.ctime:文件的状态信息发生变化的时间(文件的权限)
stat.birthtime:文件的创建时间
*/
/**
* 2、文件的读取操作
* 异步获取
* fs.readFile(path,rollback(err,data));
* err:表示读取到的错误
* data:表示读取到的数据(路径上的数据)
*/
let strpath = path.join(__dirname,'data.txt');
fs.readFile(strpath,'utf8',(err,data)=>{
if(err){
console.log('未读取到数据···');
return;
}else{
console.log(data.toString());
}
})
// //同步获取方法
let ret = fs.readFileSync(strpath,'utf8');
console.log(ret);
/**
* 大文件操作,文件在读取的时候是加载到内存中,然后从内存中进行文件的读取的,但是
* 当读取很大的文件的时候,把文件加载到内存中就会造成内存空间的不足。所以node中引入
* 了流式读取,就相当于用多少加载多少。避免占用大量的内存空间。
* fs.createReadStream(path[,options])
* fs.createWriteStream(path[,options])
*/
let spath = path.join(__dirname,'node_modules.zip');
let dpath = path.join('C:\\Users\\Administrator\\Desktop');
let readStream = fs.createReadStream(spath);
let writeStream = fs.createWriteStream(dpath);
let num = 1;
readStream.on('data',(chunk)=>{
num++;
writeStream.write(chunk);
});
readStream.on('end',()=>{
console.log('文件处理完成'+num);
});
// pipe的作用是把输入流输出给输出流
//readStream.pipe(writeStream);
/**
* 目录操作
* 1、创建目录
* 2、读取目录
*/
fs.mkdir(path.join(__dirname,'aaa'),(err)=>{
console.log(err);
})
fs.rmdir(path.join(__dirname,'aaa'),(err)=>{
console.log(err);
})