国产99久久精品_欧美日本韩国一区二区_激情小说综合网_欧美一级二级视频_午夜av电影_日本久久精品视频

最新文章專題視頻專題問答1問答10問答100問答1000問答2000關鍵字專題1關鍵字專題50關鍵字專題500關鍵字專題1500TAG最新視頻文章推薦1 推薦3 推薦5 推薦7 推薦9 推薦11 推薦13 推薦15 推薦17 推薦19 推薦21 推薦23 推薦25 推薦27 推薦29 推薦31 推薦33 推薦35 推薦37視頻文章20視頻文章30視頻文章40視頻文章50視頻文章60 視頻文章70視頻文章80視頻文章90視頻文章100視頻文章120視頻文章140 視頻2關鍵字專題關鍵字專題tag2tag3文章專題文章專題2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章專題3
當前位置: 首頁 - 科技 - 知識百科 - 正文

Node.js本地文件操作之文件拷貝與目錄遍歷的方法_node.js

來源:懂視網 責編:小采 時間:2020-11-27 20:50:49
文檔

Node.js本地文件操作之文件拷貝與目錄遍歷的方法_node.js

Node.js本地文件操作之文件拷貝與目錄遍歷的方法_node.js:文件拷貝 NodeJS 提供了基本的文件操作 API,但是像文件拷貝這種高級功能就沒有提供,因此我們先拿文件拷貝程序練手。與 copy 命令類似,我們的程序需要能接受源文件路徑與目標文件路徑兩個參數。 小文件拷貝 我們使用 NodeJS 內置的 fs 模塊簡單實現這個
推薦度:
導讀Node.js本地文件操作之文件拷貝與目錄遍歷的方法_node.js:文件拷貝 NodeJS 提供了基本的文件操作 API,但是像文件拷貝這種高級功能就沒有提供,因此我們先拿文件拷貝程序練手。與 copy 命令類似,我們的程序需要能接受源文件路徑與目標文件路徑兩個參數。 小文件拷貝 我們使用 NodeJS 內置的 fs 模塊簡單實現這個

文件拷貝
NodeJS 提供了基本的文件操作 API,但是像文件拷貝這種高級功能就沒有提供,因此我們先拿文件拷貝程序練手。與 copy 命令類似,我們的程序需要能接受源文件路徑與目標文件路徑兩個參數。

小文件拷貝
我們使用 NodeJS 內置的 fs 模塊簡單實現這個程序如下。

以上程序使用 fs.readFileSync 從源路徑讀取文件內容,并使用 fs.writeFileSync 將文件內容寫入目標路徑。

豆知識: process 是一個全局變量,可通過 process.argv 獲得命令行參數。由于 argv[0] 固定等于 NodeJS 執行程序的絕對路徑,argv[1] 固定等于主模塊的絕對路徑,因此第一個命令行參數從 argv[2] 這個位置開始。

大文件拷貝
上邊的程序拷貝一些小文件沒啥問題,但這種一次性把所有文件內容都讀取到內存中后再一次性寫入磁盤的方式不適合拷貝大文件,內存會爆倉。對于大文件,我們只能讀一點寫一點,直到完成拷貝。因此上邊的程序需要改造如下。

以上程序使用 fs.createReadStream 創建了一個源文件的只讀數據流,并使用 fs.createWriteStream 創建了一個目標文件的只寫數據流,并且用 pipe 方法把兩個數據流連接了起來。連接起來后發生的事情,說得抽象點的話,水順著水管從一個桶流到了另一個桶。

遍歷目錄

遍歷目錄是操作文件時的一個常見需求。比如寫一個程序,需要找到并處理指定目錄下的所有JS文件時,就需要遍歷整個目錄。

遞歸算法
遍歷目錄時一般使用遞歸算法,否則就難以編寫出簡潔的代碼。遞歸算法與數學歸納法類似,通過不斷縮小問題的規模來解決問題。以下示例說明了這種方法。

上邊的函數用于計算 N 的階乘(N!)。可以看到,當 N 大于 1 時,問題簡化為計算 N 乘以 N-1 的階乘。當 N 等于 1 時,問題達到最小規模,不需要再簡化,因此直接返回 1。

陷阱: 使用遞歸算法編寫的代碼雖然簡潔,但由于每遞歸一次就產生一次函數調用,在需要優先考慮性能時,需要把遞歸算法轉換為循環算法,以減少函數調用次數。

遍歷算法
目錄是一個樹狀結構,在遍歷時一般使用深度優先+先序遍歷算法。深度優先,意味著到達一個節點后,首先接著遍歷子節點而不是鄰居節點。先序遍歷,意味著首次到達了某節點就算遍歷完成,而不是最后一次返回某節點才算數。因此使用這種遍歷方式時,下邊這棵樹的遍歷順序是 A > B > D > E > C > F。

 A
 / \
 B C
 / \ \
 D E F

同步遍歷
了解了必要的算法后,我們可以簡單地實現以下目錄遍歷函數。

可以看到,該函數以某個目錄作為遍歷的起點。遇到一個子目錄時,就先接著遍歷子目錄。遇到一個文件時,就把文件的絕對路徑傳給回調函數。回調函數拿到文件路徑后,就可以做各種判斷和處理。因此假設有以下目錄:

- /home/user/
 - foo/
 x.js
 - bar/
 y.js
 z.css

使用以下代碼遍歷該目錄時,得到的輸入如下。

/home/user/foo/x.js
/home/user/bar/y.js
/home/user/z.css

異步遍歷
如果讀取目錄或讀取文件狀態時使用的是異步API,目錄遍歷函數實現起來會有些復雜,但原理完全相同。travel函數的異步版本如下。

這里不詳細介紹異步遍歷函數的編寫技巧,在后續章節中會詳細介紹這個。總之我們可以看到異步編程還是蠻復雜的。

聲明:本網頁內容旨在傳播知識,若有侵權等問題請及時與本網聯系,我們將在第一時間刪除處理。TEL:177 7030 7066 E-MAIL:11247931@qq.com

文檔

Node.js本地文件操作之文件拷貝與目錄遍歷的方法_node.js

Node.js本地文件操作之文件拷貝與目錄遍歷的方法_node.js:文件拷貝 NodeJS 提供了基本的文件操作 API,但是像文件拷貝這種高級功能就沒有提供,因此我們先拿文件拷貝程序練手。與 copy 命令類似,我們的程序需要能接受源文件路徑與目標文件路徑兩個參數。 小文件拷貝 我們使用 NodeJS 內置的 fs 模塊簡單實現這個
推薦度:
  • 熱門焦點

最新推薦

猜你喜歡

熱門推薦

專題
Top 主站蜘蛛池模板: 亚洲 欧美 日韩 小说 另类 | 国产一区二区在线播放 | 天天爱夜夜操 | 成人在线一区二区 | 在线播放一区二区三区 | 欧美日韩国 | 伊人网伊人影院 | 最新国产小视频在线播放 | 四虎影在线永久免费观看 | 天堂精品高清1区2区3区 | 在线视频亚洲 | 日韩亚洲欧洲在线com91tv | 欧美国产日韩一区二区三区 | 亚洲1页| 国产成人亚洲欧美三区综合 | 国产精品不卡在线 | 国语视频| 在线播放精品一区二区啪视频 | 亚洲美女一区二区三区 | 高清 国产 日韩 欧美 | 国内精品视频在线播放 | 中文字幕一区二区三区在线观看 | 日韩一区二区免费视频 | 日韩亚洲欧美日本精品va | 亚洲欧美自拍一区 | 成人毛片免费免费 | 国内在线视频 | 国产在线视频一区 | 国产免费一区二区三区 | 91精品国产综合久久久久久 | 亚洲欧美影视 | 久久久久久久国产精品 | 中文字幕无线码一区 | 亚洲色图第1页 | 免费观看a毛片一区二区不卡 | 亚洲一区中文字幕在线观看 | 欧美爆操 | 亚洲国产日韩欧美 | 精品一区二区三区三区 | 成人a毛片久久免费播放 | 国产一区二区自拍视频 |