nodeks —— fs模塊 —— 從流中 讀取和寫入數據
Fs流讀取和寫入數據
使用文件流來讀取大文件不會卡頓
1, 從流中讀取數據
var fs = require("fs");
var data = ‘‘;
var count = 0;
// 創建可讀流
var readerStream = fs.createReadStream(‘t.txt‘);
// 設置編碼為 utf8。
readerStream.setEncoding(‘UTF8‘);
// 處理流事件 --> data, end, and error
readerStream.on(‘data‘, function(chunk) {
data += chunk;
count++
});
readerStream.on(‘end‘,function(){
console.log(data);
console.log(count); //count:讀取次數
});
readerStream.on(‘error‘, function(err){
console.log(err.stack);
});
console.log("程序執行完畢");
2, 寫入流
var fs = require("fs");
var data = ‘ ----- 數據庫數據 ----- ‘;
// 創建一個可以寫入的流,寫入到文件 t.txt 中
var writerStream = fs.createWriteStream(‘t.txt‘);
// 使用 utf8 編碼寫入數據
writerStream.write(data,‘UTF8‘);
// 標記文件末尾
writerStream.end();
// 處理流事件 --> data, end, and error
writerStream.on(‘finish‘, function() {
console.log("寫入完成。");
});
writerStream.on(‘error‘, function(err){
console.log(err.stack);
});
console.log("程序執行完畢");
3, 管道流
var fs = require(‘fs‘)
var readerStream = fs.createReadStream(‘t.txt‘)
// 1,覆蓋原來內容
// var writerStream = fs.createWriteStream(‘pipe.txt‘)
// 2.原內容後追加
var writerStream = fs.createWriteStream(‘pipe.txt‘,{ ‘flags‘: ‘a‘ })
readerStream.pipe(writerStream)
console.log(‘管道輸送完成‘)
4, 鏈式流
鏈式是通過連接輸出流到另外一個流並創建多個流操作鏈的機制。鏈式流一般用於管道操作。
接下來我們就是用管道和鏈式來壓縮和解壓文件。
創建 compress.js 文件, 代碼如下:
var fs = require("fs");
var zlib = require(‘zlib‘);
// 壓縮 input.txt 文件為 input.txt.gz
fs.createReadStream(‘input.txt‘)
.pipe(zlib.createGzip())
.pipe(fs.createWriteStream(‘input.txt.gz‘));
console.log("文件壓縮完成。");
代碼執行結果如下:
$ node compress.js
文件壓縮完成。
執行完以上操作後,我們可以看到當前目錄下生成了 input.txt 的壓縮文件 input.txt.gz。
接下來,讓我們來解壓該文件,創建 decompress.js 文件,代碼如下:
var fs = require("fs");
var zlib = require(‘zlib‘);
// 解壓 input.txt.gz 文件為 input.txt
fs.createReadStream(‘input.txt.gz‘)
.pipe(zlib.createGunzip())
.pipe(fs.createWriteStream(‘input.txt‘));
console.log("文件解壓完成。");
代碼執行結果如下:
$ node decompress.js
文件解壓完成。
nodeks —— fs模塊 —— 從流中 讀取和寫入數據