国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 語言 > JavaScript > 正文

Node.JS枚舉統計當前文件夾和子目錄下所有代碼文件行數

2024-05-06 15:35:32
字體:
來源:轉載
供稿:網友

使用Node.JS的大多數用記事本開發,有時侯會需要統計工程代碼量,然后記事本大部分沒有這個功能。其實用node.js幾行代碼就可以實現。

var path = require('path')var fs  = require('fs')//需要統計的文件類型,可自己刪減,均小寫var codesFiles = [ '.css', '.js', '.html', '.tmpl', '.part', '.json', '.md', '.txt', '.yml', '.java', '.cs', '.c', '.h', '.cpp', '.xml', '.go', '.py' ]var LINES = 0var findFolder = function(srcDir, cb) { fs.readdir(srcDir, function(err, files) {  var count = 0  var checkEnd = function() {   ++count == files.length && cb && cb()  }  if (err) {   checkEnd()   return  }  files.forEach(function(file) {   var extname = path.extname(file).toLowerCase()   var srcPath = path.join(srcDir, file)   fs.stat(srcPath, function(err, stats) {    if (stats.isDirectory()) {     findFolder(srcPath, checkEnd)    } else {     if (codesFiles.indexOf(extname) < 0) {      checkEnd()      return     }     fs.readFile(srcPath, function(err, data) {      if (err) {       checkEnd()       return      }      var lines = data.toString().split('/n')      LINES += lines.length      console.log(srcPath, lines.length)      checkEnd()     })    }   })  })  //為空時直接回調  files.length === 0 && cb && cb() })}findFolder('./', function() { console.log('LINES:', LINES)})

使用時將此腳本文件命名為lines.js,然后復制到需要統計的文件夾下,然后執行

node lines.js

然后會統計每一個代碼文件的長度,和代碼總行數:

$ node lines.jslines.js 56package.json 6local/en-US.js 122local/FE.zh-CN.js 306...LINES: 40464

更新

下面的腳本通過檢測是否含有ASC0的值來判斷文件是不文本文件,然后統計代碼行數,但實測統計數量明顯偏多。

var path = require('path')var fs  = require('fs')var LINES = 0var FILES = 0//https://github.com/hellosean1025/study/blob/master/function.jsfunction isTextFile( filepath, length ) { fd = fs.openSync( filepath, 'r' ); length = length || 1000; for( var i = 0;i < length;i++ ) {   buf = new Buffer( 1 );   var bytes = fs.readSync( fd, buf, 0, 1, i );   char = buf.toString().charCodeAt();   if ( bytes === 0) {     return true;   } else if(bytes === 1 && char === 0) {     return false;   } } return true;}var findFolder = function(srcDir, cb) { fs.readdir(srcDir, function(err, files) {  var count = 0  var checkEnd = function() {   ++count == files.length && cb && cb()  }  if (err) {   checkEnd()   return  }  files.forEach(function(file) {   var extname = path.extname(file).toLowerCase()   var srcPath = path.join(srcDir, file)   fs.stat(srcPath, function(err, stats) {    if (stats.isDirectory()) {     findFolder(srcPath, checkEnd)    } else {     // if (codesFiles.indexOf(extname) < 0) {     //  checkEnd()     //  return     // }     if (!isTextFile(srcPath)) {      checkEnd()      return     }     fs.readFile(srcPath, function(err, data) {      if (err) {       checkEnd()       return      }      var lines = data.toString().split('/n')      LINES += lines.length      if (lines.length > 5000) {       console.trace(srcPath, lines.length)             } else {       console.log(srcPath, lines.length)      }      FILES++      checkEnd()     })    }   })  })  //為空時直接回調  files.length === 0 && cb && cb() })}findFolder('./', function() { console.log('LINES:', LINES) console.log('FILES:', FILES)})            
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表

圖片精選

主站蜘蛛池模板: 霍邱县| 巨鹿县| 岳普湖县| 崇文区| 玉田县| 兴业县| 秦皇岛市| 玉树县| 通辽市| 大田县| 长宁区| 舒城县| 沙河市| 茶陵县| 芮城县| 哈巴河县| 白山市| 康马县| 淳安县| 景德镇市| 大同市| 高陵县| 儋州市| 林西县| 福鼎市| 永平县| 汤原县| 平果县| 长海县| 仲巴县| 盖州市| 娱乐| 西平县| 宁远县| 文成县| 偏关县| 禹州市| 长沙县| 乌兰浩特市| 西充县| 梧州市|