NodeJS遍歷檔案生產檔案清單功能範例
本文實例講述了NodeJS遍歷文件生產文件清單功能。分享給大家供大家參考,具體如下:
功能需求:在工作中我們可能經常需要知道項目中靜態文件列表發布,一個一個去檢索寫,那就太苦逼了。
要想知道裡面的文件列表是不是很蛋疼,可能我們也會有dos tree去獲取。
這裡分享一下,透過node,知道檔案路徑,並配置遠端路徑,直接copy,發布。
新建filelist.js 裡面都有註釋,我就不哆嗦了.
var fs = require("fs"); //path模块,可以生产相对和绝对路径 var path = require("path"); //配置远程路径 var remotePath = "/resource/fd/promote/201507/qixi/"; //获取当前目录绝对路径,这里resolve()不传入参数 var filePath = path.resolve(); //读取文件存储数组 var fileArr = []; //读取文件目录 fs.readdir(filePath,function(err,files){ if(err){ console.log(err); return; } var count = files.length; //console.log(files); var results = {}; files.forEach(function(filename){ //filePath+"/"+filename不能用/直接连接,Unix系统是”/“,Windows系统是”\“ fs.stat(path.join(filePath,filename),function(err, stats){ if (err) throw err; //文件 if(stats.isFile()){ if(getdir(filename) == 'html'){ var newUrl=remotePath+filename; fileArr.push(newUrl); writeFile(fileArr); } // (getdir(filename) == 'html')&&(fileArr.push(filename);writeFile(newUrl)); // console.log("%s is file", filename); }else if(stats.isDirectory()){ // console.log("%s is a directory文件目录", filename); //返回指定文件名的扩展名称 //console.log(path.extname("pp/index.html")); if(filename == 'css' || filename == 'images'){ //var readurl = filePath+'/'+filename; //filePath+"/"+filename不能用/直接连接,Unix系统是”/“,Windows系统是”\“ // console.log(path.join(filePath,filename)); var name = filename; readFile(path.join(filePath,filename),name); } } }); }); }); //获取后缀名 function getdir(url){ var arr = url.split('.'); var len = arr.length; return arr[len-1]; } //获取文件数组 function readFile(readurl,name){ console.log(name); var name = name; fs.readdir(readurl,function(err,files){ if(err){console.log(err);return;} files.forEach(function(filename){ // console.log(path.join(readurl,filename)); fs.stat(path.join(readurl,filename),function(err, stats){ if (err) throw err; //是文件 if(stats.isFile()){ var newUrl=remotePath+name+'/'+filename; fileArr.push(newUrl); writeFile(fileArr) //是子目录 }else if(stats.isDirectory()){ var dirName = filename; readFile(path.join(readurl,filename),name+'/'+dirName); //利用arguments.callee(path.join())这种形式利用自身函数,会报错 //arguments.callee(path.join(readurl,filename),name+'/'+dirName); } }); }); }); } // 写入到filelisttxt文件 function writeFile(data){ var data = data.join("\n"); fs.writeFile(filePath+"/"+"filelist.txt",data+'\n',function(err){ if(err) throw err; console.log("写入成功"); }); }
當我們執行
node flielist.js
就會生產filelist.txt,文件裡面就包含了我們想要的路徑。
有時,我們通常遇到刪除不了的文件,由於文件縱深太長導致rm _rf也刪不了,但是我們透過nodejs可以辦到:
var fs = require("fs"); var path = require("path"); deleteFolderRecursive = function(url) { var files = []; //判断给定的路径是否存在 if( fs.existsSync(url) ) { //返回文件和子目录的数组 files = fs.readdirSync(url); files.forEach(function(file,index){ // var curPath = url + "/" + file; var curPath = path.join(url,file); //fs.statSync同步读取文件夹文件,如果是文件夹,在重复触发函数 if(fs.statSync(curPath).isDirectory()) { // recurse deleteFolderRecursive(curPath); // 是文件delete file } else { fs.unlinkSync(curPath); } }); fs.rmdirSync(url); }else{ console.log("给定的路径不存在,请给出正确的路径"); } }; deleteFolderRecursive("./grunt");
程式設計有所幫助。 更多NodeJS遍歷文件生產文件列表功能範例相關文章請關注PHP中文網!

熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

Video Face Swap
使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

熱工具

記事本++7.3.1
好用且免費的程式碼編輯器

SublimeText3漢化版
中文版,非常好用

禪工作室 13.0.1
強大的PHP整合開發環境

Dreamweaver CS6
視覺化網頁開發工具

SublimeText3 Mac版
神級程式碼編輯軟體(SublimeText3)

JavaScript是現代Web開發的基石,它的主要功能包括事件驅動編程、動態內容生成和異步編程。 1)事件驅動編程允許網頁根據用戶操作動態變化。 2)動態內容生成使得頁面內容可以根據條件調整。 3)異步編程確保用戶界面不被阻塞。 JavaScript廣泛應用於網頁交互、單頁面應用和服務器端開發,極大地提升了用戶體驗和跨平台開發的靈活性。

Python和JavaScript開發者的薪資沒有絕對的高低,具體取決於技能和行業需求。 1.Python在數據科學和機器學習領域可能薪資更高。 2.JavaScript在前端和全棧開發中需求大,薪資也可觀。 3.影響因素包括經驗、地理位置、公司規模和特定技能。

實現視差滾動和元素動畫效果的探討本文將探討如何實現類似資生堂官網(https://www.shiseido.co.jp/sb/wonderland/)中�...

學習JavaScript不難,但有挑戰。 1)理解基礎概念如變量、數據類型、函數等。 2)掌握異步編程,通過事件循環實現。 3)使用DOM操作和Promise處理異步請求。 4)避免常見錯誤,使用調試技巧。 5)優化性能,遵循最佳實踐。

JavaScript的最新趨勢包括TypeScript的崛起、現代框架和庫的流行以及WebAssembly的應用。未來前景涵蓋更強大的類型系統、服務器端JavaScript的發展、人工智能和機器學習的擴展以及物聯網和邊緣計算的潛力。

如何在JavaScript中將具有相同ID的數組元素合併到一個對像中?在處理數據時,我們常常會遇到需要將具有相同ID�...

zustand異步操作中的數據更新問題在使用zustand狀態管理庫時,經常會遇到異步操作導致數據更新不及時的問題。 �...
