本文基于Node.js v6.9.4,詳情請參考官網(wǎng)API
- 文件操作推薦使用絕對路徑(__dirname + filename)锨络;
- 錯誤優(yōu)先原則,callback 默認(rèn)第一個參數(shù)都是
err
一捷泞、文件操作
// 引入fs和path模塊
var fs = require('fs');
var path = require('path');
// 定義要操作的文件路徑
var PATH = path.join(__dirname,'./test.json');
1. 異步讀取文件
/* fs.readFile(filename[, options], callback)
* filename 必選參數(shù)足删,文件名
* [options] 可選參數(shù),可指定encodeing (如'utf8');可指定flag(默認(rèn)為'r',只讀)
* callback 讀取文件后的回調(diào)函數(shù)锁右,參數(shù)默認(rèn)第一個err, 第二個為 data
*/
fs.readFile(PATH,(err, res) => {
if(err){ return console.log(error); }
console.log('異步讀取成功:'+ res);
});
**2. 同步讀取文件 **
// fs.readFileSync(filename[, options])
var data = fs.readFileSync(PATH);
console.log('同步讀取'+data.toString());
3. 異步寫文件
// fs.writeFile(file, data[, options], callback) 請確保data是string類型
fs.writeFile(PATH,'{"a":"我是通過寫入的內(nèi)容"}',(err) => {
if(err){ return console.error(err);}
console.log('文件寫入成功');
});
4. 同步寫文件
fs.writeFileSync(file, data[, options])
5. 以追加方式異步寫入文件
// fs.appendFile(filename,data,[options],callback)
fs.appendFile(PATH,'// 我只是一只小母雞',(err) => {
if(err){return console.error(err);}
console.log('文件寫入成功');
});
**6. 以追加方式同步寫入文件 **
fs.appendFileSync(filename,data,[options])
7. 流式文件寫入
// fs.createWriteStream(path[, options])
var streamWriter = fs.createWriteStream(path.join(__dirname,'./test.json'));
streamWriter.write('hello', () => {
console.log('寫入成功失受!');
});
8. 文件改名
// fs.rename(oldPath, newPath, callback)
fs.rename('serve.js','http.js',(err) => {
if(err){return console.error(err);}
console.log('文件改名成功!');
});
**9. 文件異步刪除 **
// fs.unlink(path, callback)
fs.unlink('./test.json', (err) => {
if(err){ console.log(err); }
console.log('文件刪除成功咏瑟!');
});
10. 文件同步刪除
fs.unlinkSync(path)
11. 打開文件
// fs.open(path, flags[, mode], callback)
/**
* path, 必選參數(shù)拂到,文件路徑
* flags, 操作標(biāo)識,如"r",讀方式打開
* [mode],權(quán)限码泞,如777兄旬,表示任何用戶讀寫可執(zhí)行
* callback 打開文件后回調(diào)函數(shù),參數(shù)默認(rèn)第一個err,第二個fd為一個整數(shù)余寥,表示打開文件返回的文件描述符领铐,window中又稱文件句柄
*/
fs.open(PATH, 'r+', (err, fd) => {
if(err){
return console.error(err);
}
// 截取文件
fs.ftruncate(fd, 10, (err) => {
if(err){console.log(err);}
});
var buf = new Buffer(1024);
fs.read(fd, buf, 0, buf.length, 0, (err, bytes) => {
if(err){
console.log(err);
}
console.log(bytes + '字節(jié)被讀取');
// 僅輸出讀取的字節(jié)
if(bytes >0 ){
console.log(buf.slice(0,bytes).toString());
}
// 刷新緩存
fs.fsync(fd);
// 關(guān)閉文件
fs.close(fd,(err) => {
if(err){
console.log(err);
}
console.log('文件關(guān)閉');
})
});
});
12. 文件監(jiān)視
// fs.watchFile(filename[, options][, listener])
/*
* [options], persistent true表示持續(xù)監(jiān)視,interval單位毫秒宋舷,表示每隔多少毫秒監(jiān)視一次文件
* listener,文件變化時回調(diào)函數(shù)有兩個參數(shù)绪撵,curr為一個fs.Stat對象,被修改后文件祝蝠,prev音诈,修改前fs.stat對象
* */
fs.watchFile(__dirname+'/fs.md', (curr, prev) => {
console.log('fs.md文件發(fā)生變化');
})
13. 取消監(jiān)視文件
//fs.unwatchFile(filename, [listener])
/*
* filename,文件名
* listener绎狭,要取消的監(jiān)聽事件细溅,如果不指定,則取消所有監(jiān)聽處理事件
* */
var listener = (curr, prev) => {
console.log(curr);
}
fs.unwatchFile(__dirname+'/fs.md', listener);
二儡嘶、目錄操作
1. 創(chuàng)建目錄
// fs.mkdir(path, [mode], callback)
// 在當(dāng)前目錄下 的app目錄下喇聊,創(chuàng)建一個js文件夾
fs.mkdir(__dirname + 'app/js', (err) => {
if(err){console.log(err);}
console.log('目錄創(chuàng)建成功!');
});
**2. 刪除目錄 **
// fs.rmdir(path, callback)
fs.rmdir('app', (err) => {
if(err){return console.error(err);}
console.log('目錄刪除成功!');
});
3. 讀取目錄
// fs.readdir(path, callback)
/**
* path, 要讀取目錄的完整路徑及目錄名蹦狂;
* [callback(err, files)], 讀完目錄回調(diào)函數(shù)承疲;err錯誤對象邻耕,files數(shù)組,存放讀取到的目錄中的所有文件名
*/
4. 目錄改名
// fs.rename(oldPath, newPath, callback)
fs.rename(__dirname + 'app/',__dirname + 'dist/',(err) => {
if(err){return console.error(err);}
console.log('文件改名成功燕鸽!');
});
三兄世、文件或目錄操作
1. 監(jiān)視目錄或文件
fs.watch 不太穩(wěn)定,在不同系統(tǒng)上可能有兼容性問題
// fs.watch(filename, [options], [listener])
/*
* filename 完整路徑及文件名或目錄名
* [options] ,可選參數(shù)啊研,可設(shè)置編碼格式encoding(如'utf8');persistent(true/false),指定進(jìn)程是否繼續(xù)運(yùn)行御滩,當(dāng)文件被監(jiān)控到變化時;recursive(true/false),指定子文件夾是否會被監(jiān)控
* [listener(event, filename)],監(jiān)視器事件党远,有兩個參數(shù)削解,event為事件名,filename為變化的文件名
* */
var fsWatcher = fs.watch(__dirname+'/fs.md', (event, filename) =>{
console.log('event',event);
console.log('filename',filename);
})
2. 查看文件或目錄是否存在
// fs.existsSync(path)
3. 查看文件或目錄的信息,通常在讀寫文件之前使用
// fs.stat(path,callback)
/*
* callback(err, stats) 回調(diào)函數(shù)提供了兩個參數(shù)沟娱,err氛驮,錯誤信息;stats济似,文件狀態(tài)信息矫废,stats還有一下方法
* */
fs.stat(__dirname+'/fs.md', (err,stats) => {
if(err){
throw Error(err)
}
// 是否文件
stats.isFile();
// 是否問文件夾
stats.isDirectory();
// 是否為塊設(shè)備
stats.isBlockDevice();
// 是否為字符設(shè)備
stats.isCharacterDevice();
// 是否為FIFO
stats.isFIFO();
// 是否為Socket
stats.isSocket();
})