標籤:建立 get argv 資料流 命令列參數 程式 讀數 logs file
Node.js提供了檔案操作的api,但沒有直接拷貝檔案的相關操作。不過可以利用fs模組寫個簡單的拷貝檔案程式。
var fs = require(‘fs‘);function copy(filename,src) { fs.writeFileSync(filename, fs.readFileSync(src)); //filename如果不存在,則會在路徑上建立檔案}function main(argv) { copy(argv[0], argv[1]); //argv[0]為要拷貝的檔案名稱,argv[1]為拷貝資料的來源 }fs.stat(process.argv.slice(2)[1], function (err, stats) { //檢驗是否為檔案 if(stats.isFile()){ main(process.argv.slice(2)); }else{ console.log(‘invalid file‘); }});
以上程式通過stats類擷取檔案資訊,isFile判斷是否為檔案,再通過fs.writeFileSync,fs.readFileSync同步寫入或讀取檔案。
process.argv獲得命令列參數。然而argv[0],argv[1]為NodeJS執行程式的絕對路徑和運行模組的絕對路徑,所以argv[2]開始才是輸入的參數,可以通過slice()截取參數。
然而這樣的方式是將檔案內容全部先讀取至記憶體再全部一次性寫入至指定路徑,如果檔案很大,記憶體則承受不了,所以對於超大檔案的拷貝可以用資料流的方式實現,將原程式的copy函數修改一下
function copy(filename,src) { fs.createReadStream(src).pipe(fs.createWriteStream(filename));}
fs.createReadStream建立了一個唯讀資料流,fs.createWriteStream建立了一個唯寫資料流,pipe()將兩個資料流串連在一起進行傳輸。
通過資料流讀取檔案時,會將大檔案分多次進行讀取,即使檔案沒讀取完也可以對讀取的資料進行操作,寫入檔案也是如此,用這種方式來拷貝資料是十分高效的。
檔案操作相關API:http://nodejs.cn/api/fs.html
node.js 拷貝檔案