學(xué)習(xí)Nodejs之fs模塊的使用詳解
Nodejs 中的 fs 模塊的使用
1、fs.stat 檢測(cè)是文件還是目錄

const fs = require('fs')
fs.stat('./html', (err, data) => {
if (err) {
console.log(err)
return
}
console.log(`是文件:${data.isFile()}`)
console.log(`是目錄:${data.isDirectory()}`)
})
fs.stat('./package.json', (err, data) => {
if (err) {
console.log(err)
return
}
console.log(`是文件:${data.isFile()}`)
console.log(`是目錄:${data.isDirectory()}`)
})

2、fs.mkdir 創(chuàng)建目錄
最初的目錄

const fs = require('fs')
/*
path 將創(chuàng)建的目錄路徑
mode 目錄權(quán)限(讀寫權(quán)限),默認(rèn)777
callback 回調(diào),傳遞異常參數(shù)err
*/
fs.mkdir('./css', (err) => {
if (err) {
console.log(err)
return
}
console.log('創(chuàng)建成功')
})
執(zhí)行代碼后


再次執(zhí)行代碼,提示已經(jīng)創(chuàng)建了

3、fs.writeFile 創(chuàng)建寫入文件

const fs = require('fs')
/*
filename (String) 文件名稱
data (String | Buffer) 將要寫入的內(nèi)容,可以使字符串 或 buffer數(shù)據(jù)。
options (Object) option數(shù)組對(duì)象,包含:
· encoding (string) 可選值,默認(rèn) ‘utf8′,當(dāng)data使buffer時(shí),該值應(yīng)該為 ignored。
· mode (Number) 文件讀寫權(quán)限,默認(rèn)值 438
· flag (String) 默認(rèn)值 ‘w'
callback {Function} 回調(diào),傳遞一個(gè)異常參數(shù)err。
*/
fs.writeFile('./html/index.html', '你好nodejs', (err) => {
if (err) {
console.log(err)
return
}
console.log('創(chuàng)建寫入文件成功')
})



如果重復(fù)寫入,會(huì)替換內(nèi)容
4、fs.appendFile 追加文件

const fs = require('fs')
fs.appendFile('./css/base.css', 'body{color:red}', (err) => {
if (err) {
console.log(err);
return;
}
console.log('appendFile 成功');
})
執(zhí)行代碼后


如果重復(fù)執(zhí)行代碼,會(huì)追加其后,不會(huì)替代
5、fs.readFile 讀取文件
const fs = require('fs')
fs.readFile('./html/index.html', (err, data) => {
if (err) {
console.log(err);
return;
}
console.log(data)
console.log(data.toString()) //把Buffer轉(zhuǎn)換為string類型
})

6、fs.readdir 讀取目錄
const fs = require('fs')
fs.readdir('./html', (err, data) => {
if (err) {
console.log(err);
return;
}
console.log(data)
})

7、fs.rename 重命名
功能:1、表示重命名 2、移動(dòng)文件

const fs = require('fs')
fs.rename('./css/base.css', './css/index.css', (err) => {
if (err) {
console.log(err);
return;
}
console.log('重命名成功')
})
執(zhí)行代碼后

再看一下移動(dòng)文件怎么用

const fs = require('fs')
fs.rename('./css/index.css', './html/index.css', (err) => {
if (err) {
console.log(err);
return;
}
console.log('移動(dòng)文件成功')
})
執(zhí)行代碼后

8、fs.rmdir 刪除目錄

const fs = require('fs')
fs.rmdir('./html/aaa', (err) => {
if (err) {
console.log(err);
return;
}
console.log('刪除目錄成功')
})
執(zhí)行代碼之后

再看一個(gè)例子

const fs = require('fs')
fs.rmdir('./html/aaa', (err) => {
if (err) {
console.log(err);
return;
}
console.log('刪除目錄成功')
})
執(zhí)行代碼之后,發(fā)現(xiàn)并沒(méi)有刪除掉aaa這個(gè)目錄,而是報(bào)錯(cuò)了,這是因?yàn)?/p>
注意,如果這個(gè)目錄下有文件,需要先將文件刪除之后,再進(jìn)行刪除目錄的操作

9、fs.unlink 刪除文件

const fs = require('fs')
fs.unlink('./html/aaa/aaa.html', (err) => {
if (err) {
console.log(err);
return;
}
console.log('刪除文件成功')
})
執(zhí)行代碼之后

10、第三方的mkdirp

const mkdirp = require('mkdirp')
mkdirp('./upload/aaa/bbb').then(made => console.log(`made directories, starting with ${made}`))
執(zhí)行代碼之后

11、綜合練習(xí)
1.判斷服務(wù)器上面有沒(méi)有upload目錄。如果沒(méi)有創(chuàng)建這個(gè)目錄,如果有的話不做操作。

//1.判斷服務(wù)器上面有沒(méi)有upload目錄。如果沒(méi)有創(chuàng)建這個(gè)目錄,如果有的話不做操作。
const fs = require('fs')
const path = './upload'
fs.stat(path, (err, data) => {
if (err) {
//沒(méi)有這個(gè)目錄,執(zhí)行創(chuàng)建目錄
mkDir(path)
}
if (data.isDirectory()) {
console.log('創(chuàng)建失敗,已經(jīng)有這個(gè)目錄了')
} else {
//沒(méi)有這個(gè)目錄,如果有同樣命名的文件,需要?jiǎng)h除這個(gè)文件之后,再去創(chuàng)建目錄
fs.unlink(path, (err) => {
if (!err) {
mkDir(path)
} else {
console.log('請(qǐng)檢測(cè)傳入的數(shù)據(jù)是否正確')
}
})
}
})
function mkDir (path) {
fs.mkdir(path, (err) => {
if (err) {
console.log(err)
return
}
})
}
執(zhí)行代碼之后

2、練習(xí):wwwroot文件夾下面有images css js 以及index.html , 找出 wwwroot目錄下面的所有的目錄,然后放在一個(gè)數(shù)組中

//wwwroot文件夾下面有images css js 以及index.html , 找出 wwwroot目錄下面的所有的目錄,然后放在一個(gè)數(shù)組中
const fs = require('fs');
//錯(cuò)誤的寫法 注意:fs里面的方法是異步
/* var path = './wwwroot';
var dirArr = [];
fs.readdir(path, (err, data) => {
if (err) {
console.log(err);
return;
}
for (let i = 0; i < data.length; i++) {
fs.stat(path + '/' + data[i], (error, stats) => {
if (stats.isDirectory()) {
dirArr.push(data[i]);
}
})
}
console.log(dirArr); //[]
})
console.log(dirArr); //[] */
//打印出 3個(gè)3
// for (var i = 0; i < 3; i++) {
// setTimeout(function () {
// console.log(i);
// }, 100)
// }
//1、改造for循環(huán) 遞歸實(shí)現(xiàn)
var path = './wwwroot';
var dirArr = [];
fs.readdir(path, (err, data) => {
if (err) {
console.log(err);
return;
}
(function getDir (i) {
if (i == data.length) { //執(zhí)行完成
console.log(dirArr);
return;
}
fs.stat(path + '/' + data[i], (error, stats) => {
if (stats.isDirectory()) {
dirArr.push(data[i]);
}
getDir(i + 1)
})
})(0)
})
// 2、nodejs里面的新特性 async await
//1、定義一個(gè)isDir的方法判斷一個(gè)資源到底是目錄還是文件
async function isDir(path) {
return new Promise((resolve,reject) => {
fs.stat(path, (error, stats) => {
if (error) {
console.log(error);
reject(error)
return;
}
if (stats.isDirectory()) {
resolve(true);
} else {
resolve(false);
}
})
})
}
//2、獲取wwwroot里面的所有資源 循環(huán)遍歷
function main(){
var path='./wwwroot'
var dirArr=[];
fs.readdir(path,async (err,data)=>{ //注意
if(err){
console.log(err);
return;
}
for(var i=0;i<data.length;i++){
if(await isDir(path+'/'+data[i])){
dirArr.push(data[i]);
}
}
console.log(dirArr);
})
}
main();
12、fs.createReadStream 從文件流中讀取數(shù)據(jù)
const fs=require('fs');
var readStream=fs.createReadStream('./data/input.txt');
var count=0;
var str='';
readStream.on('data',(data)=>{
str+=data;
count++;
})
readStream.on('end',()=>{
console.log(str);
console.log(count)
})
readStream.on('error',(err)=>{
console.log(err);
})

13、fs.createWriteStream 寫入文件
var fs = require("fs");
var data = '我是從數(shù)據(jù)庫(kù)獲取的數(shù)據(jù),我要保存起來(lái)'; // 創(chuàng)建一個(gè)可以寫入的流,寫入到文件 output.txt 中
var writerStream = fs.createWriteStream('output.txt');
// 使用 utf8 編碼寫入數(shù)據(jù)
writerStream.write(data,'UTF8');
// 標(biāo)記文件末尾
writerStream.end();
// 處理流事件 --> finish 事件
writerStream.on('finish', function() {
/*finish - 所有數(shù)據(jù)已被寫入到底層系統(tǒng)時(shí)觸發(fā)。*/
console.log("寫入完成。");
});
writerStream.on('error', function(err){
console.log(err.stack);
});
console.log("程序執(zhí)行完畢");
14、管道流
管道提供了一個(gè)輸出流到輸入流的機(jī)制。通常我們用于從一個(gè)流中獲取數(shù)據(jù)并將數(shù)據(jù)傳 遞到另外一個(gè)流中。
var fs = require("fs");
// 創(chuàng)建一個(gè)可讀流
var readerStream = fs.createReadStream('input.txt');
// 創(chuàng)建一個(gè)可寫流
var writerStream = fs.createWriteStream('output.txt');
// 管道讀寫操作
// 讀取 input.txt 文件內(nèi)容,并將內(nèi)容寫入到 output.txt 文件中
readerStream.pipe(writerStream);
console.log("程序執(zhí)行完畢");
總結(jié)
本篇文章就到這里了,希望能給您帶來(lái)幫助, 也希望您能夠多多關(guān)注腳本之家的更多內(nèi)容!
相關(guān)文章
node.js express捕獲全局異常的三種方法實(shí)例分析
這篇文章主要介紹了node.js express捕獲全局異常的三種方法,結(jié)合實(shí)例形式簡(jiǎn)單分析了node.js express捕獲全局異常的常見(jiàn)操作方法與使用注意事項(xiàng),需要的朋友可以參考下2019-12-12
如何開(kāi)發(fā)一個(gè)漸進(jìn)式Web應(yīng)用程序PWA
這篇文章主要介紹了如何開(kāi)發(fā)一個(gè)漸進(jìn)式Web應(yīng)用程序PWA,對(duì)漸進(jìn)式Web應(yīng)用程序感興趣的同學(xué),可以參考下2021-05-05
window10系統(tǒng)下nvm詳細(xì)安裝步驟以及使用
nvm可以管理不同版本的node和npm,可以簡(jiǎn)單操作node版本的切換、安裝、查看等,下面這篇文章主要給大家介紹了關(guān)于window10系統(tǒng)下nvm詳細(xì)安裝步驟以及使用的相關(guān)資料,需要的朋友可以參考下2022-07-07
nodejs實(shí)現(xiàn)OAuth2.0授權(quán)服務(wù)認(rèn)證
本篇文章主要介紹了nodejs實(shí)現(xiàn)OAuth2.0授權(quán)服務(wù)認(rèn)證,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2017-12-12
簡(jiǎn)單易懂的nvm和Node.js版本控制的實(shí)現(xiàn)
NVM是Node.js的版本管理工具,可以方便地在不同版本的Node.js之間切換,本文主要介紹了簡(jiǎn)單易懂的nvm和Node.js版本控制的實(shí)現(xiàn),具有一定的參考價(jià)值,感興趣的可以了解一下2023-10-10
Node.js 應(yīng)用跑得更快 10 個(gè)技巧
Node.js 受益于它的事件驅(qū)動(dòng)和異步的特征,已經(jīng)很快了。本文將介紹 10 條,經(jīng)過(guò)檢驗(yàn)得知可大大提高 Node 應(yīng)用的技巧。廢話不多說(shuō),讓我們逐條來(lái)看看2016-04-04
Linux使用Node.js建立訪問(wèn)靜態(tài)網(wǎng)頁(yè)的服務(wù)實(shí)例詳解
這篇文章主要介紹了Linux使用Node.js建立訪問(wèn)靜態(tài)網(wǎng)頁(yè)的服務(wù)實(shí)例詳解的相關(guān)資料,需要的朋友可以參考下2017-03-03

