成人怡红院-成人怡红院视频在线观看-成人影视大全-成人影院203nnxyz-美女毛片在线看-美女免费黄

站長(zhǎng)資訊網(wǎng)
最全最豐富的資訊網(wǎng)站

nodejs的哪個(gè)模塊可以操作文件

nodejs的“文件系統(tǒng)”模塊可以操作文件。fs(文件系統(tǒng))模塊是nodejs提供的用于訪問(wèn)本地文件系統(tǒng)的功能模塊,使用fs模塊可以實(shí)現(xiàn)文件及目錄的創(chuàng)建,寫入、刪除等操作。

nodejs的哪個(gè)模塊可以操作文件

本教程操作環(huán)境:windows7系統(tǒng)、nodejs 12.19.0版、Dell G3電腦。

一、fs模塊簡(jiǎn)介

1. 基本概念

fs(file system)模塊是nodejs提供的用于訪問(wèn)本地文件系統(tǒng)的功能模塊,它使得運(yùn)行于nodejs環(huán)境下的JavaScript具備直接讀寫本地文件的能力。

fs模塊是nodejs的核心模塊之一,只要安裝了nodejs,就可以直接使用,不需要單獨(dú)安裝。引入fs模塊非常簡(jiǎn)單:

let fs = require('fs');

接下來(lái)就可以調(diào)用fs模塊的相關(guān)接口直接讀寫文件系統(tǒng)。

fs模塊主要提供了以下的接口類:

  • fs.Dir,目錄類。可理解為文件夾。

  • fs.Dirent,目錄項(xiàng)類。通過(guò)Dir類的返回值獲得,表示該目錄下的一個(gè)子項(xiàng),可能是文件或子目錄。

  • fs.FSWatcher,文件監(jiān)聽類,它可以為一個(gè)文件創(chuàng)建一個(gè)監(jiān)聽器,當(dāng)文件變化時(shí)觸發(fā)回調(diào)。

  • fs.StatWatcher,調(diào)用fs.watchFile()方法之后的返回值類型,主要用于協(xié)助控制事件循環(huán)。

  • fs.ReadStream,讀取流。當(dāng)流式讀取文件時(shí)需要使用該類。

  • fs.Stats,文件元信息類。通過(guò)該類可以獲取文件相關(guān)信息(如文件類型、文件大小、文件描述符等)。

  • fs.WriteStream,寫入流。當(dāng)流式寫入數(shù)據(jù)時(shí)需要使用。

除了以上的類,fs模塊還提供了非常多的實(shí)例方法,它們可以直接通過(guò)fs調(diào)用,如讀取文件的方法reafFile

let fs = require('fs');  fs.readFile('./README.md', function(err, data) = {   if (err) throw err;   ... // 處理數(shù)據(jù) })

該函數(shù)以異步的方式讀取文件,以可能拋出的異常作為回調(diào)函數(shù)的第一個(gè)參數(shù)(這樣設(shè)計(jì)的目的是“強(qiáng)制”或者“提醒”開發(fā)者去處理可能出現(xiàn)的異常),而真正的文檔數(shù)據(jù)則作為第二個(gè)參數(shù)。

fs模塊中幾乎所有默認(rèn)的讀寫函數(shù)都是異步的,不過(guò)它也同時(shí)提供了這些函數(shù)的同步版本,一般是在函數(shù)后面加Sync。如上面的代碼還可以用readFileSync改寫:

let fs = require('fs');  try {   let data = fs.readFileSync('./README.md', 'utf8'); } catch(e = {   console.error(e); })

大多數(shù)情況下,nodejs推薦使用異步版本的讀寫函數(shù)來(lái)提升系統(tǒng)性能。而如果要使用同步版本的函數(shù),應(yīng)該盡可能使用try catch捕獲異常,以防止讀寫失敗造成主線程崩潰。

2. 文件路徑

既然是文件系統(tǒng)模塊,就必然要根據(jù)文件路徑找到需要操作的文件。fs模塊支持的路徑類型分為三類:字符串、BufferURL對(duì)象。

(1). 字符串

字符串類是最常用的路徑類型,包括絕對(duì)路徑相對(duì)路徑。絕對(duì)路徑指的是相對(duì)于文件系統(tǒng)根目錄的路徑,而相對(duì)路徑是相對(duì)于當(dāng)前工作目錄的路徑(即運(yùn)行node命令時(shí)所在的目錄,可以通過(guò)process.cwd()獲取到)。

當(dāng)使用絕對(duì)路徑時(shí),windows和其他操作系統(tǒng)存在一定差異。因?yàn)樵谄渌蠖鄶?shù)操作系統(tǒng)中,驅(qū)動(dòng)器只有唯一的根目錄;而在windows上,則存在多個(gè)獨(dú)立的驅(qū)動(dòng)盤(如C盤、D盤等)。從寫法上來(lái)看,絕對(duì)路徑一般是以/開頭,表示驅(qū)動(dòng)盤的根目錄:

fs.readFile('/README.md', (err, data) => {   ... });

而在windows上,則是以驅(qū)動(dòng)盤開頭的:

fs.readFile('d://nodejs/README.md', (err, data) => {   ... })

我們知道,一般windows都是使用反斜線作為路徑分隔符的。不過(guò)在nodejs中作了兼容,使用斜線或者反斜線都可以正確識(shí)別,因此下面的寫法也是正確的:

fs.readFile('d:\nodejsREADME.md', (err, data) => {   ... })

需要注意的是,當(dāng)使用fs.readdir('c:')讀取C盤目錄時(shí),實(shí)際上讀取的是c:\userxxx這個(gè)用戶根目錄,必須加雙斜線或雙反斜線,才可以讀取到真正的c盤根目錄:fs.readdir('c://')

而相對(duì)路徑則是相對(duì)于當(dāng)前工作目錄的路徑,通常以../(回退到上級(jí)目錄)、./(當(dāng)前目錄)或當(dāng)前路徑下的某個(gè)目錄項(xiàng)開頭。如:

// 當(dāng)前目錄的上一級(jí)目錄下的README.md文件 fs.readFileSync('../README.md');  // 當(dāng)前目錄下nodejs文件夾內(nèi)的README.md fs.readFileSync('./nodejs/README.md'); fs.readFileSync('nodejs/README.md');

./開頭表示當(dāng)前目錄,可以直接省略。

(2). Buffer

Buffer類型的路徑和字符串幾乎沒(méi)有差別,只是某些操作系統(tǒng)將文件路徑視為二進(jìn)制字節(jié)序列,因此通常需要用Buffer.from('README.md')的方式將字符串路徑轉(zhuǎn)化為二進(jìn)制字節(jié)序列。由于這類操作系統(tǒng)比較少用,這里不再詳細(xì)介紹。

(3). URL

URL(uniform resource locator,統(tǒng)一資源定位器)是一種通用的資源定位方案,它將任意資源(包括本地文件)都視為網(wǎng)絡(luò)資源,然后以一種統(tǒng)一的方式定位它們。

fs模塊僅支持使用file協(xié)議的URL對(duì)象,該協(xié)議的前綴為file:///,路徑格式如下:

// 在windows下,定位某個(gè)主機(jī)上的文件, // 一般用于讀寫局域網(wǎng)內(nèi)的共享文件夾 fs.readFileSync(new URL('file:///主機(jī)名/README.md'));  // 定位本地資源 fs.readFileSync(new URL('file:///c:/README.md'));

以上兩種寫法都是針對(duì)windows平臺(tái)的,第一種主要用于局域網(wǎng)內(nèi)的共享文件讀取,第二種用于讀寫本地文件。

對(duì)于其他平臺(tái),url的格式如下:

fs.readFileSync(new URL('file:///nodejs/README.md'));

它會(huì)被轉(zhuǎn)化為絕對(duì)路徑:/nodejs/README.md。URL類型的路徑不支持相對(duì)路徑。

二、fs模塊的常用類

鑒于fs模塊的接口數(shù)量較為龐大,這里暫不一一探討,如果感興趣,請(qǐng)參考 nodejs中文網(wǎng) – fs模塊。本文主要是介紹以下幾個(gè)接口類中較為常用的一些api,基本上可以滿足大部分文件系統(tǒng)操作的需求:

  • fs.Dir

  • fs.Dirent

  • fs.ReadStream

  • fs.Stats

  • fs.WriteStream

1. fs.Dir(v12.12)

這是fs模塊對(duì)目錄(或稱為文件夾)的抽象類。調(diào)用fs.opendir()fs.opendirSync()fsPromises.opendir()這三個(gè)方法時(shí)會(huì)返回一個(gè)Dir類型的對(duì)象,用于操作打開后的目錄。

比如我們要遍歷當(dāng)前文件夾下的所有子目錄及文件,可以用下面的代碼(v12.12以上版本可用):

async function getChild (path) {   // 讀取目錄子項(xiàng),返回一個(gè)promise   let dir = await fs.promises.opendir(path);    for await (let dirent of dir) {     console.log(dirent.name);   }}

關(guān)閉目錄有三個(gè)方法:dir.close()dir.close(callback)dir.closeSync()。

dir.close()返回的是一個(gè)promise,向其注冊(cè)then方法可以在目錄關(guān)閉后執(zhí)行回調(diào)函數(shù),如dir.close().then((e) => { ... });dir.close(callback)是關(guān)閉目錄的異步方法,直接傳入回調(diào)函數(shù),它會(huì)在文件關(guān)閉后調(diào)用;dir.closeSync()是關(guān)閉目錄的同步方法,只有目錄成功關(guān)閉后才會(huì)執(zhí)行后續(xù)代碼。

dir.path的值為當(dāng)前目錄的路徑,即調(diào)用opendir方法時(shí)傳入的路徑。

讀取該目錄的目錄項(xiàng)的三個(gè)方法為:dir.read()、dir.read(callback)dir.readSync()。

dir.read()返回的是一個(gè)promise數(shù)組或null,分別負(fù)責(zé)讀取每一個(gè)目錄項(xiàng),主要用于async函數(shù)遍歷:

async function read (path) {   let dir = await fs.promises.opendir(path);   for await (let dirent of dir.read()){     ...   }}

dir.read(callback)則是讀取目錄項(xiàng)的異步版本,每次讀取到一個(gè)子項(xiàng),就會(huì)調(diào)用一次callback;dir.readSync()是讀取目錄項(xiàng)的同步版本,返回的是Dirent類型的數(shù)組或null。

2. fs.Dirent(v10.10)

目錄項(xiàng)類。當(dāng)通過(guò)fs.opendir()方法讀取一個(gè)目錄時(shí),它的每一個(gè)子項(xiàng)就是一個(gè)Dirent類對(duì)象,每個(gè)Dirent對(duì)象可能是一個(gè)子目錄,或者是一個(gè)文件。每個(gè)Dirent對(duì)象都是文件名和文件類型組成的。

fs.Dirent提供的方法主要是用于判斷目錄項(xiàng)類型:

  • dirent.isBlockDevice(),是否為塊設(shè)備。

  • dirent.isCharacterDevice(),是否為字符設(shè)備。

  • dirent.isDirectory(),是否為系統(tǒng)目錄。

  • dirent.isFIFO(),是否為先入先出通道。

  • dirent.isFile(),是否為普通文件。

  • dirent.isSocket(),是否為套接字。

  • dirent.isSymbolicLink(),是否為符號(hào)鏈接,即快捷方式。

另外,dirent.name的值為目錄項(xiàng)的名字。

3. fs.ReadStream

讀取流類,用于流式讀取文件。該類由fs.createReadStream()創(chuàng)建并返回。

fs.ReadStream支持三個(gè)事件:

  • close,讀取流關(guān)閉事件。

  • open,讀取流打開事件。

  • ready,讀取流就緒事件,在open事件發(fā)生后立即觸發(fā)。

回調(diào)函數(shù)接收文件描述符fd作為參數(shù),用于對(duì)文件的后續(xù)操作。

fs.ReadStream實(shí)例有三個(gè)實(shí)例屬性:

  • readStream.bytesRead,已讀取的字節(jié)數(shù)。

  • readStream.path,文件路徑。

  • readStream.pending,文件是否就緒(ready事件發(fā)生前,該值為true,發(fā)生后變?yōu)閒alse)。

4. fs.Stats

提供對(duì)文件信息的描述。調(diào)用fs.stat()、fs.lstat()fs.fstat()會(huì)返回該類型的對(duì)象。

一個(gè)fs.Stats實(shí)例包含以下屬性:

Stats {   dev: 2114,  // 設(shè)備的數(shù)字標(biāo)識(shí)符   ino: 48064969,  // 設(shè)備的索引號(hào)   mode: 33188,  // 文件類型和模式   nlink: 1,  // 文件的硬鏈接數(shù)   uid: 85,  // 該文件擁有者的標(biāo)識(shí)符   gid: 100,  // 擁有該文件的群組的標(biāo)識(shí)符   rdev: 0,  // 數(shù)字型設(shè)備表標(biāo)識(shí)符   size: 527,  // 文件大小,單位為字節(jié)   blksize: 4096,  // 文件系統(tǒng)塊的大小   blocks: 8,  // 文件系統(tǒng)為當(dāng)前文件分配的塊數(shù)   atimeMs: 1318289051000.1,  // 上次被訪問(wèn)時(shí)間   mtimeMs: 1318289051000.1,  // 上次被修改的時(shí)間   ctimeMs: 1318289051000.1,  // 上次更改文件狀態(tài)的時(shí)間   birthtimeMs: 1318289051000.1,  // 文件的創(chuàng)建時(shí)間   atime: Mon, 10 Oct 2011 23:24:11 GMT,  // 以上四個(gè)時(shí)間的另一種格式   mtime: Mon, 10 Oct 2011 23:24:11 GMT,   ctime: Mon, 10 Oct 2011 23:24:11 GMT,   birthtime: Mon, 10 Oct 2011 23:24:11 GMT    }

每個(gè)Stats對(duì)象還可以返回一個(gè)bigint類型的結(jié)果,它的每個(gè)結(jié)果都是bigint類型,而不是上面的number類型,這里不再詳述。

同時(shí),它還有與Dirent相同的7個(gè)實(shí)例方法,來(lái)判斷當(dāng)前的設(shè)備類型,請(qǐng)參考上述Dirent。

5. fs.WriteStream

寫入流類,用于流式地寫入數(shù)據(jù)。它由fs.createWriteStream()創(chuàng)建和返回。

fs.ReadStream類似,它也有close、openready三個(gè)事件,兩者的用法也是一樣的。

每個(gè)WriteStream實(shí)例也都有三個(gè)實(shí)例屬性:writeStream.bytesWrittenwriteStream.pathwriteStream.pending,分別表示當(dāng)前已寫入的字節(jié)數(shù)、寫入流文件路徑和是否已就緒,與ReadStream也是類似的。

三、fs模塊的常用方法

fs模塊提供了很多讀寫文件系統(tǒng)資源的函數(shù),上一部分介紹的類主要是對(duì)這些函數(shù)操作結(jié)果的封裝。下面來(lái)介紹一些常用的方法:

1. fs.access(path [,mode], callback)

檢查文件的可用性。

第一個(gè)參數(shù)path為文件路徑,可以是字符串、Buffer或URL類型;
第二個(gè)參數(shù)為要檢查的類型,可能的值包括fs.constants.F_OK(是否存在,默認(rèn)值)、fs.constants.R_OK(是否可讀)和fs.constants.W_OK(是否可寫);
第三個(gè)參數(shù)為回調(diào)函數(shù),如果檢查失敗,則會(huì)傳入一個(gè)Error對(duì)象,否則會(huì)傳入undefined。

比如我們需要檢查當(dāng)前文件夾下是否存在package.json,可以這樣寫:

fs.access('package.json', fs.constants.F_OK, (err) => {   if (err) {     ... // 文件存在   } else {     ... // 文件不存在   }})

一般來(lái)說(shuō),不應(yīng)該在檢查文件可用性之后立即讀寫文件,因?yàn)閺臋z查文件可用性到實(shí)際讀寫文件的過(guò)程中,該文件的狀態(tài)可能發(fā)生變化(比如其他進(jìn)程操作了該文件),這會(huì)導(dǎo)致文件可用性檢查失效。因此fs.access方法通常只用來(lái)檢查文件的可用性,而要讀寫文件的話,可以直接調(diào)用讀寫文件的方法,再根據(jù)回調(diào)函數(shù)接收到的可能的異常來(lái)判斷該文件是否可用。

該方法還有一個(gè)同步版本:fs.accessSync(path [,mode]),前兩個(gè)參數(shù)與異步版本是一致的。當(dāng)文件檢查成功時(shí),該方法返回undefined,否則將拋出異常,用法如下:

try {   fs.accessSync('package.json', fs.constants.R_OK | fs.constants.W_OK);   console.log('可以讀寫');   } catch (err) {   console.error('無(wú)權(quán)訪問(wèn)');   }

2. fs.appendFile(path, data[, options], callback)

向文件中追加數(shù)據(jù)。

path支持字符串、Buffer和URL類型;
data為要追加的數(shù)據(jù),可以是字符串或Buffer實(shí)例;
options為配置對(duì)象,包含三個(gè)參數(shù):

  • encoding,編碼方式,默認(rèn)為utf8

  • mode,模式,默認(rèn)為0o666。該參數(shù)為文件的權(quán)限描述,0o666表示為每個(gè)用戶擁有讀寫權(quán)限。

  • flag,文件操作方式,默認(rèn)為a,即追加。

callback為函數(shù)執(zhí)行完畢的回調(diào)函數(shù),如果追加失敗,則第一個(gè)參數(shù)為錯(cuò)誤對(duì)象,否則為undefined。例子如下:

fs.appendFile('README.md', '這是要添加的數(shù)據(jù)', (err) => {   if (err) {     console.log('數(shù)據(jù)追加失敗');   } else {     console.log('數(shù)據(jù)追加成功');   }})

該方法的同步版本為fs.appendFileSync(path, data[, options])。與accessSync一樣,它也只是移除了最后一個(gè)參數(shù)callback,通過(guò)返回值來(lái)判斷操作結(jié)果,這里不再重復(fù)舉例。

3. fs.chmod(path, mode, callback)

修改文件的權(quán)限。

文件系統(tǒng)中每個(gè)文件都有讀、寫和執(zhí)行三個(gè)權(quán)限,用r、w和x表示。其中r的權(quán)重為4,w的權(quán)重為2,x的權(quán)重為1,即當(dāng)用戶擁有讀權(quán)限時(shí),權(quán)限值加4,擁有寫權(quán)限時(shí)權(quán)限值加2,擁有執(zhí)行權(quán)限時(shí)權(quán)限值加1。

權(quán)限類型 權(quán)重
讀權(quán)限 4
寫權(quán)限 2
執(zhí)行權(quán)限 1

這種權(quán)重分配使得任何一種權(quán)限擁有情況的權(quán)限值都是不同的,因此只需要一個(gè)八進(jìn)制數(shù)字就可以表示某個(gè)用戶對(duì)某個(gè)文件擁有哪些權(quán)限。

比如某個(gè)用戶擁有對(duì)某個(gè)文件的讀寫權(quán)限,而沒(méi)有執(zhí)行權(quán)限,則他的權(quán)限值為4 + 2 + 0 = 6。而如果同時(shí)擁有這三個(gè)權(quán)限,則權(quán)限值為4 + 2 + 1 = 7。

對(duì)一個(gè)文件而言,系統(tǒng)中存在三類用戶:文件的擁有者、擁有該文件的用戶組和其他用戶。文件系統(tǒng)使用三個(gè)八進(jìn)制數(shù)字,來(lái)表示這三類用戶對(duì)某個(gè)文件的權(quán)限。比如當(dāng)某個(gè)文件的權(quán)限值為0o761時(shí),它表示:

  • 文件的擁有者具備讀、寫和執(zhí)行權(quán)限:7 = 4 + 2 + 1

  • 文件所屬的用戶組成員具備讀寫權(quán)限:6 = 4 + 2 + 0

  • 其他成員只具備執(zhí)行權(quán)限:1 = 0 + 0 + 1

fs.chmod方法就是用來(lái)修改某個(gè)文件權(quán)限的。它可以傳入三個(gè)參數(shù),分別是文件路徑、權(quán)限值和回調(diào)函數(shù)。權(quán)限值就是上面所講的三個(gè)八進(jìn)制數(shù)字,如0o761;如果修改失敗,則回調(diào)函數(shù)接收異常對(duì)象,否則沒(méi)有參數(shù)。

該方法的同步版本為fs.chmodeSync(path, mode),用法與其他同步方法一致。

4. fs.chown(path, uid, gid, callback)

修改文件的擁有者。

第一個(gè)參數(shù)為文件路徑;第二個(gè)參數(shù)為新的文件擁有者的用戶標(biāo)識(shí)符;第三個(gè)參數(shù)為該文件所屬的用戶組的標(biāo)識(shí)符,最后一個(gè)參數(shù)為執(zhí)行完畢后的回調(diào)函數(shù)。

uid和gid都是number類型,是文件系統(tǒng)為每個(gè)用戶和用戶組分配的唯一id,callback則會(huì)在操作失敗時(shí)得到一個(gè)錯(cuò)誤對(duì)象。

該方法的同步版本為fs.chownSync(path, uid, gid),使用方法與其他同步方法一致。

5. fs.close(fd, callback)

異步地關(guān)閉一個(gè)文件。

第一個(gè)參數(shù)fd是調(diào)用fs.open打開一個(gè)文件時(shí),文件系統(tǒng)為該文件分配的一個(gè)數(shù)字類型的文件描述符;當(dāng)文件關(guān)閉失敗時(shí),callback會(huì)得到一個(gè)異常對(duì)象。如:

fs.open('README.md', 'a', (err, fd) => {   ...   fs.close(fd, (err) => {     if (err) {}  // 關(guān)閉失敗   });   })

該方法的異步版本為fs.closeSync(fd)。

6. fs.constants

fs模塊提供的常量,參見fs常量。

7. fs.copyFile(src, dest[, mode], callback)

拷貝一個(gè)文件。

第一個(gè)參數(shù)src為拷貝源的地址,數(shù)據(jù)類型與path一致;
第二個(gè)參數(shù)dest為目標(biāo)地址,數(shù)據(jù)類型也與path一致;
第三個(gè)可選參數(shù)為拷貝參數(shù),默認(rèn)情況下,將創(chuàng)建或覆蓋(文件已存在時(shí))目標(biāo)文件。除了這個(gè)默認(rèn)值,還有以下三個(gè)可選值:

  • fs.constants.COPYFILE_EXCL – 如果 dest 已存在,則拷貝操作將失敗。

  • fs.constants.COPYFILE_FICLONE – 拷貝操作將嘗試創(chuàng)建寫時(shí)拷貝(copy-on-write)鏈接。如果平臺(tái)不支持寫時(shí)拷貝,則使用后備的拷貝機(jī)制。

  • fs.constants.COPYFILE_FICLONE_FORCE – 拷貝操作將嘗試創(chuàng)建寫時(shí)拷貝鏈接。如果平臺(tái)不支持寫時(shí)拷貝,則拷貝操作將失敗。

第四個(gè)參數(shù)為為執(zhí)行之后回調(diào)函數(shù),與其他異步函數(shù)一致,它也會(huì)在失敗時(shí)接收到一個(gè)異常對(duì)象。

它的同步版本為fs.copyFileSync(src, dest[, mode])。

8. fs.createReadStream(path[, options])

創(chuàng)建一個(gè)讀取流。常見用法為:

let fs = require('fs'); let rs = fs.createReadStream('./1.txt',{     highWaterMark:3, //文件一次讀多少字節(jié),默認(rèn) 64*1024     flags:'r', //默認(rèn) 'r'     autoClose:true, //默認(rèn)讀取完畢后自動(dòng)關(guān)閉     start:0, //讀取文件開始位置     end:3, //流是閉合區(qū)間 包含start也含end     encoding:'utf8' //默認(rèn)null }); rs.on("open",()=>{    console.log("文件打開") }); // 自動(dòng)觸發(fā)data事件 直到讀取完畢 rs.on('data',(data)=>{     console.log(data); });

9. fs.createWriteStream(path[, options])

創(chuàng)建一個(gè)寫入流。常見用法為:

const fs=require('fs'); const path=require('path'); let writeStream=fs.createWriteStream('./test/b.js',{encoding:'utf8'});  //讀取文件發(fā)生錯(cuò)誤事件 writeStream.on('error', (err) => {     console.log('發(fā)生異常:', err); }); //已打開要寫入的文件事件 writeStream.on('open', (fd) => {     console.log('文件已打開:', fd); }); //文件寫入完成事件 writeStream.on('finish', () => {     console.log('寫入已完成..');     console.log('讀取文件內(nèi)容:', fs.readFileSync('./test/b.js', 'utf8')); //打印寫入的內(nèi)容     console.log(writeStream); });   //文件關(guān)閉事件 writeStream.on('close', () => {     console.log('文件已關(guān)閉!'); });   writeStream.write('這是我要做的測(cè)試內(nèi)容'); writeStream.end();

10. 基于文件描述符的一組函數(shù)

fs.fchown(fd, callback)、fs.fchmod(fd, callbakc)等,它是將第一個(gè)參數(shù)從path替換為了文件對(duì)應(yīng)的文件描述符,使用這類方法之前需要先通過(guò)fs.open`打開文件,獲取文件描述符。這里不再詳述。

11. fs.mkdir(path[, options], callback)

創(chuàng)建一個(gè)目錄(即文件夾)。

第一個(gè)參數(shù)path為要?jiǎng)?chuàng)建文件夾的路徑;
第二個(gè)參數(shù)options支持兩個(gè)參數(shù):

  • recursive,是否遞歸創(chuàng)建父目錄,默認(rèn)為false。

  • mode,創(chuàng)建的文件夾的權(quán)限,默認(rèn)是0o777。

第三個(gè)參數(shù)為執(zhí)行完畢的回調(diào)函數(shù),它的第一個(gè)參數(shù)為可能的異常對(duì)象,當(dāng)recursivetrue時(shí),它還會(huì)得到一個(gè)path參數(shù),值為當(dāng)前操作創(chuàng)建的第一個(gè)目錄。

而當(dāng)要?jiǎng)?chuàng)建的目錄已經(jīng)存在時(shí),如果recursive為false,則會(huì)拋出異常,否則不會(huì)執(zhí)行任何操作。

創(chuàng)建目錄的用法如下:

fs.mkdir('nodejs/lib', {recursive: true}, (err, path) => {   ...})

該代碼試圖在當(dāng)前路徑下的nodejs文件夾內(nèi)創(chuàng)建lib文件夾,并且要遞歸地創(chuàng)建父目錄。即假如當(dāng)前目錄下沒(méi)有nodejs文件夾,則先創(chuàng)建它。創(chuàng)建完成后,如果nodejs文件夾是新創(chuàng)建的,則path就是它的路徑;如果nodejs已經(jīng)存在了,則path是新創(chuàng)建的lib文件夾的路徑。

該方法的同步版本為fs.mkdirSync(path[, options])

12. fs.open(path[, flags[, mode]], callback)

打開一個(gè)文件。

第一個(gè)參數(shù)為要打開的文件的路徑;
第二個(gè)參數(shù)為打開方式,如r(只讀),w(只寫),a(追加)等;
第三個(gè)參數(shù)為文件權(quán)限,默認(rèn)為0o666(讀寫權(quán)限);
最后一個(gè)參數(shù)為回調(diào)函數(shù),它有兩個(gè)參數(shù),第一個(gè)為可能拋出的異常對(duì)象,第二個(gè)是文件系統(tǒng)為被打開的文件分配的數(shù)值類型的文件描述符fd
如:

fs.open('README.md', 'r', (err, fd) => {   ...   fs.close(fd, (err) => {})})

它的同步版本為fs.openSync(path[, flags[, mode]])

13. fs.opendir(path[, options], callback)

打開一個(gè)目錄。

第一個(gè)參數(shù)為目錄的路徑;
第二個(gè)參數(shù)包含兩個(gè)參數(shù):

  • encoding,編碼類型,默認(rèn)utf8

  • bufferSize,操作該目錄時(shí)要緩沖的目錄項(xiàng)的數(shù)量,默認(rèn)值32,值越大則性能越好,但內(nèi)存消耗會(huì)更大

第三個(gè)參數(shù)為callback,即打開目錄后的回調(diào)函數(shù)。該回調(diào)函數(shù)可接受兩個(gè)值,一個(gè)是可能的異常對(duì)象,另一個(gè)是打開的目錄對(duì)象,類型為fs.Dir。

它的同步版本為fs.opendirSync(path[, options])。

14. fs.readFile(path[, options], callback)

異步地讀取文件數(shù)據(jù)。

該方法會(huì)默認(rèn)先用fs.open打開文件,并在讀取完畢后自動(dòng)關(guān)閉文件。因此調(diào)用該方法不需要手動(dòng)打開和關(guān)閉文件,不過(guò)如果需要頻繁地操作文件,則該方法會(huì)導(dǎo)致文件被反復(fù)打開和關(guān)閉,造成性能下降。

path除了可以是文件路徑外,還可以是文件描述符。如果傳入的是文件描述符,則默認(rèn)在讀取完畢后不會(huì)關(guān)閉文件,并且后續(xù)的讀取會(huì)接著上次讀取的位置繼續(xù)向后。

options支持以下兩個(gè)參數(shù):

  • encoding,編碼格式,默認(rèn)為null,實(shí)際使用時(shí)一般傳入'utf8'

  • flag,讀取方式,默認(rèn)為只讀r

如果只需要指定編碼格式,options還可以是一個(gè)字符串,如'utf8'。

回調(diào)函數(shù)的第一個(gè)參數(shù)為可能的異常對(duì)象,第二個(gè)參數(shù)則是從文件中讀出的數(shù)據(jù),可能的數(shù)據(jù)類型為字符串或Buffer。如

fs.readFile('README.md', 'utf8', (err, data) => {   if (err) { console.log('讀取失敗'); }   else {     console.log(data);   }})

該方法的同步版本為fs.readFileSync(path[, options])。

另外該方法還有一個(gè)可替代方法,fs.read,請(qǐng)參考fs.read。它是在使用fs.open打開文件時(shí)通用的讀取文件的方法,對(duì)讀取過(guò)程的控制粒度更細(xì)。在對(duì)同一個(gè)文件進(jìn)行頻繁的讀取操作,一般使用該方法。

15. fs.rename(oldPath, newPath, callback)

將oldPath指定的文件重命名為newPath指定的文件,如果該文件已存在,則覆蓋它。

回調(diào)函數(shù)只接收可能拋出的異常對(duì)象。

它的同步版本為fs.renameSync(oldPath, newPath)。

16. fs.stat(path[, options], callback)

獲取某個(gè)文件的詳細(xì)信息。

fs.stat('README.md', {bigint: true}, function(err, stats) {   console.log(stats.isDirectory());   console.log(stats);   });

options僅支持bigint這一個(gè)參數(shù),表示返回的stats對(duì)象是bigint類型,而不是通常的number類型。以上操作的結(jié)果請(qǐng)參考fs.Stats類。

它的同步版本為fs.statSync(path[, options], callback)。

17. fs.writeFile(file, data[, options], callback)

類似于fs.readFile,該方法為文件的寫方法。

file參數(shù)為要寫入的文件路徑,或文件描述符。
data為要寫入的數(shù)據(jù),支持<string> 、 <Buffer> 、 <TypedArray> 、<DataView>等。
options支持三個(gè)參數(shù):encoding,默認(rèn)值’utf8’;mode,權(quán)限類型,默認(rèn)值0o666;flag,打開方式,默認(rèn)值w。

回調(diào)函數(shù)僅支持一個(gè)參數(shù),即可能拋出的異常對(duì)象。

該方法的同步版本為fs.writeFileSync(file, data[, options])。

當(dāng)使用fs.open打開一個(gè)文件時(shí),一般使用fs.write進(jìn)行數(shù)據(jù)寫入,請(qǐng)參考fs.write。該方法可以精確地控制寫入位置,并且可以連續(xù)寫入數(shù)據(jù)。

總結(jié)

以上所列舉的只是fs模塊中較為常用的一些api,官方文檔中還有很多其他用途的接口,感興趣的請(qǐng)參考nodejs中文網(wǎng) – fs模塊。

如果需要在async函數(shù)中使用上述api,可以調(diào)用fs模塊提供的promise封裝版本,如:

let fsPromises = require('fs').promises; // 或let fsPromises = require('fs/promises'); // 或let fs = require('fs'); let fsPromises = fs.promises;  fsPromise.readFile().then((err, data) => {   ... })  async function print (path) {   try {     let data = await fsPromise.readFile(path, 'utf8');     console.log(data); // 讀取成功,輸出data   } catch (e => {     ...  // 讀取失敗   }) }

【推薦學(xué)習(xí):《nodejs 教程》】

贊(1)
分享到: 更多 (0)
?
網(wǎng)站地圖   滬ICP備18035694號(hào)-2    滬公網(wǎng)安備31011702889846號(hào)
在线精品亚洲观看不卡欧| 亚洲国产精品无码久久久蜜芽 | 亚洲VA欧洲VA日韩VA| 亚洲欧美日韩综合一区二区| 又大又硬又粗再深一点视频| AV无码爆乳护士在线播放| ASSPICS亚洲美女裸体CH| 成色AU999.9是什么意思| 无码人妻束缚av又粗又大| 无码成人AⅤ免费中文字幕| 偷拍区小说区图片区另类呻吟| 无码中文国产不卡视频| 久久水蜜桃亚洲AV无码精品麻豆| 日日摸夜夜添夜夜添亚洲女人| 好大好厉害我接了一个顾客| 三级国产三级在线| 69ZXX少妇内射无码| 精品一区二区三区| 无码毛片AAA在线| 把佛珠一个一个挤出去| 久久久久国产亚洲AⅤ麻豆| 无人区码一码二码三码在线| 波多野结衣TORRENT| 免费无码AV一区二区| 亚洲精品国产情侣AV在线| 国产成人综合亚洲AV第一页| 人妻无码一区二区三区免费| 在线 | 麻豆国产传媒| 黑人高潮拔也拔不出来| 天天摸天天做天天爽水多| YY6080久久亚洲精品| 免费人成视频X8X8入口| 亚洲熟妇色XXXXX无码| 国产午夜福利片1000无码| 试看AAAA啪啪片120秒| 被老汉耸动呻吟双性美人| 内射人妻深入内射| 又爽又黄又无遮挡激情视频免费| 激情伊人五月天久久综合| 无码一区二区三区不卡AV| 给丰满少妇按摩到高潮| 人妻精品丝袜一区二区无码AV| 永久免费AV网站可以直接看的| 姬小满无限奖励别人的英雄| 香蕉国产成版人视频APP| 国产SM主人调教女M视频| 日本肥老妇色XXXXX日本老妇| 97日日碰人人模人人澡| 蜜桃传媒一区二区亚洲AV| 野花香在线观看免费观看大全动漫| 极品熟妇大蝴蝶20P| 小洞饿了想吃大香肠| 国产精品久久无码一区| 天堂√中文最新版在线中文| 丰满妇女强高潮18ⅩXXX小说| 人人妻人人澡人人爽超污 | 中文字幕亚洲综合小综合在线| 久久精品熟女亚洲AV麻豆| 亚洲精品456在线播放| 国产最大成人亚洲精品| 亚洲 国产 制服 丝袜 一区| 国产精品自在线拍国产手青青机版| 少妇夜夜春夜夜爽试看视频| 大炕上的肉体交换农村乱睡| 日韩高清国产一区在线| 成人免费AⅤ视频一区二区| 日本适合十八岁以上人群的护肤品| けんじゃたいむMANA原神| 欧洲FREEXXXX性少妇播放| А√天堂中文官网在线BT| 屁屁影院最新发布页CCYY| TPU色母和PA6色母的作用| 人妻少妇 少妇人妻第一页| ぱらだいす天堂中文WWW| 人人人妻人人澡人人爽| 成 人 黄 色 网 站 在线观| 日韩一区二区三区无码人妻视频| 成色好的Y31S标准版| 少妇的BBW性大片| 国产成人AV综合久久| 无码熟妇人妻AV在线C0930| 国产猛男GAY1069视频| 性色AV一区二区三区人妻 | 久久久久久精品免费无码| 一面亲上边一面膜下边56| 毛耸耸性XXXX毛耸耸| 3分19秒砍人手脚血腥场面| 欧美疯狂做受XXXX高潮| А√天堂网WWW在线搜索| 三上悠亚AV影院在线看| 国产成人亚洲精品无码车A| 无码专区人妻系列日韩精品| 国色天香一卡2卡3卡4卡| 亚洲色AV无码AV丰满AV| 乱亲女H秽乱长久久久| AV片在线观看免费| 日韩精品人妻系列无码专区免费| 国产成人AV无码专区亚洲AV| 亚洲ⅤA中文字幕无码| 久久不见久久见免费影院3| 中文字幕成熟丰满人妻| 人妻精品AAAA中文字幕69| 国产GAYSEXCHINA男外| 美国少归BVBV| A级国产乱理伦片在线播放| 人人妻人人妻人人片色AV| 国产A∨精品一区二区三区不卡| 午夜无码福利伦利理免| 久久AV无码精品人妻系列果冻| 在线观看AV片永久免费| 秋霞电影网免费观看| 国产高清在线观看AV片麻豆| 亚洲高清成人AV电影网站| 噜噜噜亚洲色成人网站∨| 把腿张开让老子臊烂你的动漫视频| 婷婷四房综合激情五月在线| 黑人巨大熟女高潮痉挛潮喷| 真实国产乱子伦精品一区二区三区 | 一区二区伊人久久大杳蕉| 欧洲Av无码放荡人妇网站| 国产精品国产三级在线专区| 亚洲欧洲无码精品ⅤA| 欧美狂野乱码一二三四区| 国产成人综合在线观看不卡| 亚洲乱码无人区卡1卡2卡3| 女性の乳頭を凸起しています| 丰满熟女高潮毛茸茸欧洲视频| 免费人妻无码不卡中文字幕18禁| 成熟丰满熟妇高潮XXXXX视频| 亚洲AV毛片成人精品| 蜜臀AV无码精品人妻色欲| 丰满少妇三级全黄| 亚洲精品一线二线三线无人区| 欧美精品亚洲精品日韩专区VA| 国产高清不卡一区二区| 亚洲最大AV无码网址| 日本婷婷色色电影| 狠狠色丁香久久综合| CSGO大姐姐AWP多少钱| 无套内射GIF舔B吃奶| 狼人无码精华AV午夜精品| 成人网站亚洲二区乱码| 亚洲精品自偷自拍无码| 人妻无码ΑV中文字幕久久琪琪布 人妻无码ΑV中文字幕久久 | 国产成人亚洲影院在线播放| 野花视频大全高清免费| 日韩乱码人妻无码超清蜜桃丨| 精品国产亚洲AV麻豆尤物| 八戒八戒WWW资源网在线观看| 亚洲AV乱码一区二区三区| 欧美成人午夜免费全部完| 国产品无码一区二区三区在线蜜桃| 中文字幕久久精品波多野结百度 | 国产丶欧美丶日本不卡视频| 伊人色综合久久天天| 天堂√最新版中文在线| 美女无遮挡直播软件免费看| 国产精品久久这里只有精品| 中文字幕有码中文无码| 午夜人妻免费视频| 欧美性白人极品1819HD| 娇妻卧室含辱迎接领导是哪部电影| 被黑人猛躁10次高潮视频| 亚洲伊人成无码综合网| 天堂А√在线最新版中文下载| 麻豆国产一卡二卡三卡| 国产精品未满十八禁止观看| 4虎CVT4WD| 亚洲丁香婷婷久久一区二区| 日本高清视频www| 久久久噜噜噜久久久精品| 国产成人亚洲精品无码车A| 24小时在线看免费观看直播| 亚洲AV高清在线观看一区二区三| 秋霞国产午夜伦午夜无码灬| 痉挛高潮喷水AV无码免费| 公侵犯玩弄熟睡人妻电影| 18禁爆乳无遮挡免费观看日本动| 亚洲AV乱码VA国产AV22| 日韩精品无码一区二区三区AV | 亚洲A成人无码网站在线| 日本老熟妇wwwbbb| 麻豆╳╳╳乱女另类| 国产影片AV级毛片特别刺激| 被黑人的大JJ干得很舒服吗| 曰本BBWW高潮BBWR| 亚洲AV无码国产蜜桃麻豆| 日日日日做夜夜夜夜无码| 男女作爱免费网站| 精品无码国产污污污免费| 国产成人无码久久久精品一| CSGO大姐姐AWP多少钱| 一本大道东京热无码AV| 亚洲AV无码成人精品区在线h| 娇妻宾馆被三根粗大的夹击| 国产成人AV区一区二区三| А天堂中文地址在线| 真实国产乱人伦在线视频播放| 亚洲VA国产VA天堂VA久久| 熟妇人妻精品一区二区三区颏|