亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

學(xué)習(xí)Nodejs之fs模塊的使用詳解

 更新時(shí)間:2022年02月05日 10:14:08   作者:丑小鴨變黑天鵝  
這篇文章主要為大家詳細(xì)介紹了Nodejs之fs模塊的使用,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來幫助

Nodejs 中的 fs 模塊的使用

1、fs.stat 檢測是文件還是目錄

在這里插入圖片描述

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ù)組對象,包含:
        · 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)并沒有刪除掉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ù)器上面有沒有upload目錄。如果沒有創(chuàng)建這個(gè)目錄,如果有的話不做操作。

在這里插入圖片描述

//1.判斷服務(wù)器上面有沒有upload目錄。如果沒有創(chuàng)建這個(gè)目錄,如果有的話不做操作。
const fs = require('fs')
const path = './upload'
fs.stat(path, (err, data) => {
  if (err) {
    //沒有這個(gè)目錄,執(zhí)行創(chuàng)建目錄
    mkDir(path)
  }
  if (data.isDirectory()) {
    console.log('創(chuàng)建失敗,已經(jīng)有這個(gè)目錄了')
  } else {
    //沒有這個(gè)目錄,如果有同樣命名的文件,需要?jiǎng)h除這個(gè)文件之后,再去創(chuàng)建目錄
    fs.unlink(path, (err) => {
      if (!err) {
        mkDir(path)
      } else {
        console.log('請檢測傳入的數(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ù)庫獲取的數(shù)據(jù),我要保存起來'; // 創(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é)

本篇文章就到這里了,希望能給您帶來幫助, 也希望您能夠多多關(guān)注腳本之家的更多內(nèi)容!

相關(guān)文章

最新評(píng)論