首頁 > web前端 > js教程 > 三種nodeJS中讀寫檔案方法

三種nodeJS中讀寫檔案方法

零到壹度
發布: 2018-03-28 17:27:24
原創
7528 人瀏覽過

nodejs中所有與檔案相關的操作都在fs模組中,而讀寫操作又是我們會常用到的操作,nodejs的fs模組針對讀取操作為我們提供了readFile,read, createReadStream三個方法,針對寫入操作為我們提供了writeFile,write, createWriteStream三個方法,下面分析一下它們的區別:

一、readFile和writeFile

1、readFile方法是將要讀取的檔案內容完整讀入快取區,再從該快取區讀取檔案內容,具體操作如下:

fs.readFile('./test.txt', 'utf8', function(err, data){
    console.log(data);  
});
登入後複製

與其對應的同步方法為:

var data = fs.readFileSync('./test.txt', 'utf8');
console.log(data);
登入後複製

同步方法和非同步方法的差異是:在使用同步方法執行的操作結束之前,不能執行後續程式碼的執行;而異步方法將操作結果作為回調函數的參數進行傳回,方法呼叫之後,就可以立即執行後續的程式碼,讀取完畢後會呼叫對應的回調函數。

2、writeFile方法是將要寫入的檔案內容完整的讀入快取區,然後一次性的將快取區中的內容寫入都檔案中,其同步和非同步具體操作如下:


//异步方法
fs.writeFile('./message.txt', '这是第一行',function(err){  
  if(err) console.log('写文件操作失败');    
  else console.log('写文件操作成功');
});

//同步方法
fs.writeFileSync('./message.txt','这是第一行');
登入後複製

以上的讀寫操作,Node.js將檔案內容視為一個整體,為其分配快取區並且一次性將檔案內容讀取到快取區中,在這個期間,Node.js將不能執行任何其他處理。所以當讀寫大檔案的時候,有可能造成快取區「爆倉」。

二、read和write

#1、read或readSync方法讀取檔案內容是不斷地將文件中的一小塊內容讀入快取區,最後從該快取區讀取檔案內容,具體操作如下:

var fs = require('fs');
fs.open('./message.txt','r',function(err,fd){    var buf = new Buffer(225);    //读取fd文件内容到buf缓存区
    fs.read(fd,buf,0,9,3,function(err,bytesRead,buffer){
        console.log(buf.slice(0,bytesRead).toString());
    }); 
    var buff = new Buffer(225);    //位置设置为null会默认从文件当前位置读取
    fs.read(fd,buff,0,3,null,function(err,bytesRead,buffer){
        console.log(buff.slice(0,bytesRead).toString());
    });    var buffer = new Buffer(225);    //同步方法读取文件
    var bytesRead = fs.readFileSync(fd,buffer,0,9,3);
    console.log(bytesRead);
    console.log(buffer.slice(0,bytesRead).toString());
});
登入後複製

2、write或writeSync方法寫入內容時, node.js執行以下程序:1將需要寫入的資料寫入到一個記憶體快取區;2待快取區寫滿後再將快取區中的內容寫入到檔案中;3重複執行步驟1和步驟2 ,知道資料全部寫入檔案為止。具體操作如下:

var fs = require('fs');var buf = new Buffer('我喜爱编程');
fs.open('./mess.txt','w',function(err,fd){
    fs.write(fd,buf,3,9,0,function(err,written,buffer){
        fs.write(fd,buf,12,3,null,function(err,written,buffer){            if(err) console.log('写文件操作失败');
            console.log('写文件操作成功');
        });
    });    //同步写入
    fs.writeSync(fd,buf,3,9,0);
});
登入後複製

以上讀寫操作,node.js會將檔案分成一塊一塊逐步操作,在讀寫檔案過程中允許執行其他操作。

但有的时候我们并不关心整个文件的内容,而只关注从文件中读取到的某些数据,以及读取到数据时需要执行的处理,这时我们可以使用文件流来处理。

三、createReadStream和createWriteStream

1、createReadStream方法创建一个将文件内容读取为流数据的ReadStream对象,方法如下所示:

var fs = require('fs');var readStream = fs.createReadStream('./message.txt',{start:3,end:12});
readStream.on('open',function(fd){
    console.log('开始读取文件');
});
readStream.on('data',function(data){
    console.log('读取到数据:');
    console.log(data);
});
readStream.on('end',function(){
    console.log('文件已全部读取完毕');
});
readStream.on('close',function(){
    console.log('文件被关闭');
});
readStream.on('error',function(err){
    console.log('读取文件失败');
});
登入後複製

2、createWriteStream方法创建一个将流数据写入文件中的WriteStream对象,方法如下所示:

var fs = require('fs');var file = fs.createReadStream('./message.txt');var out = fs.createWriteStream('./anotherMessage.txt');
file.on('data',function(data){
    out.write(data);
});
out.on('open',function(fd){
    console.log('需要被写入的文件已打开');
});
file.on('end',function(){    //将操作系统缓存区中的数据全部写入文件
    out.end('再见',function(){
        console.log('文件全部写入完毕');
        console.log('共写入'+out.bytesWritten+'数据');
    });
});
登入後複製

以上方法可以对读写文件的过程中进行监听,并定义相关的方法pause和resume暂停或恢复文件的读取操作,可以监听写入时缓存区数据是否已满或者是否已全部输出,如下所示:

//监听writeStream对象的drain事件var fs = require('fs');var out = fs.createWriteStream('./test1.txt');for(var i=0;i<10000;i++){    //返回true或false true代表缓存区已满
    var flag = out.write(i.toString());
    console.log(flag);
}
out.on('drain',function(){
    console.log('操作系统缓存区中的数据已全部输出');    var out = fs.createWriteStream('./test2.txt');    for(var i=0;i<10;i++){        var flag = out.write(i.toString());
        console.log(flag);
    }
    out.on('drain',function(){
        console.log('操作系统缓存区中的数据已全部输出');
    });
});
登入後複製

以上是三種nodeJS中讀寫檔案方法的詳細內容。更多資訊請關注PHP中文網其他相關文章!

相關標籤:
來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板