您好,登錄后才能下訂單哦!
NodeJs版本:4.4.4
文件系統模塊是一個封裝了標準的 POSIX 文件 I/O 操作的集合。Node.js 文件系統(fs 模塊)模塊中的方法均有異步和同步版本。
創建一個可讀流與一個寫入流。通過管道pipe
。
var fileReadStream = fs.createReadStream(sourcePath);var fileWriteStream = fs.createWriteStream(targetPath);fileReadStream.pipe(fileWriteStream);//監聽關閉事件得知執行完成fileWriteStream.on('close', function() { console.log('移動成功!'); })
定義:fs.readFile(filename[, options], callback)
參數:
filename:{String} 文件名/文件路徑
options:{Object} 可選參數
encoding:{String | Null} 默認 = null 編碼方式
flag:{String} 默認 = 'r' 文件打開的行為(可寫,可讀等)
callback:{Function}
var fs = require('fs');//讀取文件fs.readFile('../lianxi/child_process.js',{ encoding:'utf-8', flag:'r'}, function(err,data){ if(err) throw err; console.log(data);});
這里讀取文件如果不設置編碼方式,讀取的文件就是以buffer
的形式返回。<Buffer 76 61 72 20 63 68 69 6c 64 5f 70 72 6f 63 65 73 73 20 3d 20 72 65 71 75 69 72 65 28 27 63 68 69 6c 64 5f 70 72 6f 63 65 73 73 27 29 3b 0d 0a 76 61 72 ... >
設置為utf-8
后,返回的就是字符串的形式。如下:var child_process = require('child_process');...
定義:fs.writeFile(filename, data[, options], callback)
參數:
filename:{String}
data:{String | Buffer}
options:{Object}
encoding:{String | Null} 默認 = 'utf8'
mode:{Number} 默認 = 438 (aka 0666 in Octal)
flag:{String} 默認 = 'w'
callback {Function}
//寫入文件fs.writeFile('../lianxi/child_process.js','[zqz]要寫入的數據字符串或者buffer',{ encoding:'utf8', mode:438, flag:'w'},function(err){})
注意:異步寫文件,如果文件已經存在則替換。
定義:fs.open(path, flags[, mode], callback)
參數:
path:文件/文件路徑
flags:文件打開的行為
mode:設置文件模式(權限),文件創建默認權限為 0666(可讀,可寫)。
callback:回調函數
//打開文件fs.open('../lianxi/child_process.js','r+',0666,function(err,data){ })
定義:fs.appendFile(filename, data[, options], callback)
參數:
filename:{String}
data:{String | Buffer}
options:{Object}
encoding {String | Null} 默認 = 'utf8'
mode {Number} 默認 = 438 (aka 0666 in Octal)
flag {String} 默認 = 'a'
callback {Function}
//給文件添加數據fs.appendFile('../lianxi/child_process.js', '異步添加的字符串或buffer', { encoding:'utf8', mode:438, flag:'a'}, function(err){});
注意:異步的給文件添加數據,如果文件不存在,就會創建一個文件。
定義:fs.unlink(path, callback)
var fs = require('fs');fs.unlink('./t/index.html',function (err) { if(err) throw err; console.log('成功')})
定義:fs.open(path, flags[, mode], callback)
也可以使用fs.open
創建文件。
fs.open("test.txt", "w",function (err) {});
定義:fs.rmdir(path, callback)
fs.rmdir('./t/a',function (err) { if(err) throw err; console.log('成功')})
定義:fs.mkdir(path[, mode], callback)
參數:mode 默認是 to 0777.
fs.mkdir('./t/a',0777,function (err) { if(err) throw err; console.log('成功')})
定義:fs.watch(filename[, options][, listener])
定義:fs.watchFile(filename[, options], listener)
fs.watch('test.js', function (event, filename) { });fs.watchFile('test.js', function(curr, prev){ });
Flag | 描述 |
---|---|
r | 以讀取模式打開文件。如果文件不存在拋出異常。 |
r+ | 以讀寫模式打開文件。如果文件不存在拋出異常。 |
rs | 以同步的方式讀取文件。 |
rs+ | 以同步的方式讀取和寫入文件。 |
w | 以寫入模式打開文件,如果文件不存在則創建。 |
wx | 類似 'w',但是如果文件路徑存在,則文件寫入失敗。 |
w+ | 以讀寫模式打開文件,如果文件不存在則創建。 |
wx+ | 類似 'w+', 但是如果文件路徑存在,則文件讀寫失敗。 |
a | 以追加模式打開文件,如果文件不存在則創建。 |
ax | 類似 'a', 但是如果文件路徑存在,則文件追加失敗。 |
a+ | 以讀取追加模式打開文件,如果文件不存在則創建。 |
ax+ | 類似 'a+', 但是如果文件路徑存在,則文件讀取追加失敗。 |
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。