中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

node.js中怎么對文件進行操作

發布時間:2021-07-20 16:40:15 來源:億速云 閱讀:283 作者:Leah 欄目:web開發

這篇文章將為大家詳細講解有關node.js中怎么對文件進行操作,文章內容質量較高,因此小編分享給大家做個參考,希望大家閱讀完這篇文章后對相關知識有一定的了解。

一、文件操作

在文件操作里,主要是有文件讀寫,創建、移動文件等。

1.1 讀取文件

讀取文本文件時,如.txt, .js, .json等文件,直接使用readFile就可以獲取文件的內容。

// server.js
var fs = require('fs');

fs.readFile('./data.txt', 'utf-8', function(err, data){
 if(err) throw err;
 console.log(data);
});

讀取圖片時,我們是不能直接輸出到控制臺中的,是需要創建一個服務器,然后在瀏覽器上進行查看。其實在上節中,我們已經了解過顯示圖片的過程了。

// server.js
var http = require('http'),
 fs = require('fs');

http.createServer(function(request, response){
 // 使用二進制方式讀取圖片
 fs.readFile('./img/test.png', 'binary', function(err, file){
  if( err ) throw err;
  // 當前數據以image/png方式進行輸出
  response.writeHead(200, {"Content-Type": "image/png"});
  response.write(file, 'binary');
  response.end();
 });
}).listen(3000);
console.log('server has started...');

打開瀏覽器:127.0.0.1:3000,就能看到圖片了。

1.2 寫入文件

將字符串寫入到文件文件中,是非常簡單的操作,使用writeFile即可搞定:

var fs = require('fs');

var data = '從一開始,就選擇了做前端開發,因為覺得前端開發更貼近用戶,能夠傾聽用戶的聲音,更好玩,更有意思,美的更直觀。我們總是在嘗試最新的技術,嘗試更炫的效果,希望更能優化用戶的體驗效果!';

fs.writeFile('./test.txt', data, function(err){
 if(err) throw err;
 console.log('寫入數據成功...');
});

writeFile方法,在沒有文件時會創建文件并寫入;若文件存在則內容被覆蓋。

1.3 創建或文件重命名

根據writeFile的特性,可以使用writeFile寫入空字符串的方式創建文件。

同時,fs.open也可以創建文件:

// 打開模式可以使用 w | w+ | a | a+
// 這些模式在打開不存在的文件時,會創建文件
// fd為一個整數,表示打開文件返回的文件描述符,window中又稱文件句柄
fs.open(Date.now()+'.txt', 'a+', function(err, fd){
 if(err) throw err;
 console.log(fd);
})

在文件系統中,有一個fs.rename的方法,顧名思義,對文件(文件夾)進行重命名。

fs.rename(oldname, newname, callback(err));

特性:

將oldname文件(目錄)移動至newname的路徑下,并重新命名;如果oldname和newname是同一個路徑,則直接進行重命名。

二、文件夾操作

通常對目錄的操作比較簡單一些。

2.1 讀取文件夾中的文件和文件夾列表

使用fs.readdir(path, callback)可以獲取path路徑下的文件和目錄列表,而且只能讀取直接目錄下的文件和文件夾,子目錄里的是獲取不到的。

fs.readdir('./', function(err, files){
 if(err) throw err;
 console.log( files );
});

輸出結果:

[
 'img',
 'msg.txt',
 'node_modules',
 'package.json',
 'server.js',
 'test.js',
 'tmp'
]

node_modulestmp是文件夾,剩下的是文件,而且是獲取不到node_modulestmp里面的數據。獲取一個目錄下所有的文件,后面會講解,稍等。

2.2 刪除文件夾

使用fs.rmdir(path, callback)可以刪除文件夾,但只能刪除空文件夾,如果當前路徑不是文件夾或當前文件夾不為空,則刪除失敗;刪除的為空文件夾時,可以刪除成功。

fs.rmdir('./tmp', function(err){
 if(err){
  console.log('刪除文件夾失敗');
  throw err;
 }else{
  console.log('刪除成功');
 }
})

如何刪除不為空的目錄,后面會講解,稍等。

2.3 獲取文件或文件夾的信息

fs.stat(path, callback)能夠獲取path路徑的信息,比如創建時間,修改時間,文件大小,當前是否為文件,當前是否為文件夾等信息;如果path路徑不存在,則拋出異常。

fs.stat('./test.js', function(err, stats){
 if( err ){
 console.log( '路徑錯誤' );
 throw err;
 }
 console.log(stats);
 console.log( 'isfile: '+stats.isFile() ); // 是否為文件
 console.log( 'isdir: '+stats.isDirectory() ); // 是否為文件夾
});

結果:

{
 dev: -29606086,
 mode: 33206,
 nlink: 1,
 uid: 0,
 gid: 0,
 rdev: 0,
 blksize: undefined,
 ino: 2251799813687343,
 size: 2063, // path路徑為文件夾時,size為0
 blocks: undefined,
 atime: Thu Jan 12 2017 21:12:36 GMT+0800 (中國標準時間),
 mtime: Sat Jan 14 2017 21:57:26 GMT+0800 (中國標準時間),
 ctime: Sat Jan 14 2017 21:57:26 GMT+0800 (中國標準時間),
 birthtime: Thu Jan 12 2017 21:12:36 GMT+0800 (中國標準時間)
}
isfile: true // 是否為文件
isdir: false // 是否為文件夾

關于這幾個時間屬性的理解,可以參考這篇文章。

stats中的size屬性就是當前文件的大小(單位:字節,除以1024即為kb),stats還有下面方法可供使用:

  1. stats.isFile()

  2. stats.isDirectory()

  3. stats.isBlockDevice()

  4. stats.isCharacterDevice()

  5. stats.isSymbolicLink() (only valid with fs.lstat())

  6. stats.isFIFO()

  7. stats.isSocket()

fs.stat(path, callback)是異步執行的,對應的還有同步執行版本:fs.statSync(path) ,這個方法返回的就是fs.stats實例。

三、綜合運用

我們在上面的講解中,還留著兩個功能沒實現,這里實現一下它的過程。

3.1 遍歷目錄中所有的文件

我們已經知道使用readdir只能獲取當前目錄里的文件和文件夾名稱,為了獲取這個目錄里所有的文件名稱,只能是讀取當前目錄里所有的文件夾里的文件。這里我們使用遞歸的方法,如果當前資源是文件,則進行存儲,是文件夾則進行遞歸進一步檢索,直到把所有的文件夾遍歷完畢。

// 獲取文件夾中所有的文件
function readDirAll(path){
 // 獲取字符串的最后一個字符
 var getLastCode = function(str){
  return str.substr(str.length-1, 1);
 }

 var result = []; // 存儲獲取到的文件
 var stats = fs.statSync(path); // 獲取當前文件的狀態
 if( stats.isFile() ){
  result.push(path);
 }else if( stats.isDirectory() ){
  // 若當前路徑是文件夾,則獲取路徑下所有的信息,并循環
  var files = fs.readdirSync(path);

  for(var i=0, len=files.length; i<len; i++){
   var item = files[i],
    itempath = getLastCode(path)=='/' ? path+item : path+'/'+item; // 拼接路徑
   var st = fs.statSync(itempath);
   if( st.isFile() ){
    result.push(itempath);
   }else if( st.isDirectory() ){
    // 當前是文件夾,則遞歸檢索,將遞歸獲取到的文件列表與當前result進行拼接
    var s = readDirAll( itempath );
    result = result.concat( s );
   }
  }
 }
 return result;
}
console.log( readDirAll('./') );

使用此程序獲取當前目錄中所有的文件(展示的為部分文件):

[ 
 './bing.doc',
 './img/1484234634801.png',
 './img/1484234660592.png',
 './img/test.png',
 './inter.js',
 './msg.txt',
 './node_modules/formidable/.npmignore',
 './node_modules/formidable/.travis.yml',
 './node_modules/formidable/index.js',
 './node_modules/formidable/lib/file.js',
 './node_modules/formidable/lib/incoming_form.js',
 './node_modules/formidable/lib/index.js',
 ...
]

如果想要輸出一種樹形的結構,就可以對當前的遞歸程序進行改造,比如我想要輸出如下的這種結果,那么,就要分析這種結構的特點:

bing.doc         
img           
 |---1484234634801.png     
 |---1484234660592.png     
 |---test.png       
inter.js         
msg.txt          
node_modules        
 |---formidable       
  |---.npmignore      
  |---.travis.yml      
  |---index.js      
  |---lib        
   |---file.js 
   |---incoming_form.js 
   |---index.js

可以看出的規律:

  1. 第一層級的文件和文件夾前面是沒有空格和字符的;

  2. 第一級子目錄中的文件或文件夾前面是1組空格和1個字符;

  3. 第二級子目錄中的文件或文件夾前面是2組空格和1個字符;

  4. 依次類推…

我們可以再傳遞一個depth來表示當前目錄的層級,然后計算出前面空格的數量:

// depth為遞歸的深度,可根據遞歸的深度輸出文件名稱前面的格式
function readDirAll(path, depth){
 // 獲取字符串
 var getLastCode = function(str){
  return str.substr(str.length-1, 1);
 }

 depth = depth || 0; // 默認為0
 var fir_code = '';

 // 計算文件名稱前面的字符,4個空格為1組
 for(var j=0; j<depth; j++){
  fir_code += ' ';
 }
 depth && (fir_code += '|---');

 var stats = fs.statSync(path);
 if( stats.isFile() ){
  console.log( fir_code+path );
 }else if( stats.isDirectory() ){
  var files = fs.readdirSync(path);
  for(var i=0, len=files.length; i<len; i++){
   var item = files[i],
    itempath = getLastCode(path)=='/' ? path+item : path+'/'+item,
    st = fs.statSync(itempath);

   console.log( fir_code+item );
   if( st.isDirectory() ){
    var s = readDirAll( itempath, depth+1 );
   }
  }
 }
}
console.log( readDirAll('./') );

3.2 刪除目錄

使用fs.rmdir(path)是有局限性的,只能刪除空目錄,如果是個非空目錄,我們可以根據上面的思路,寫出一個能刪除當前目錄下所有的文件。遞歸,只要找到里面的文件夾就遞歸尋找,直到找到最底層,把最底層的文件刪除,然后再逐級向上刪除文件夾,直到刪除到當前目錄。

// 刪除path下所有的文件和文件夾,包括path自己
function rmDirAll(path){
 // 獲取字符串
 var getLastCode = function(str){
  return str.substr(str.length-1, 1);
 }

 var stats = fs.statSync(path); // 獲取當前文件的狀態
 if( stats.isFile() ){
  fs.unlinkSync(path);
  console.log( '刪除成功: '+path );
 }else if( stats.isDirectory() ){
  // 若當前路徑是文件夾,則獲取路徑下所有的信息,并循環
  var files = fs.readdirSync(path);

  for(var i=0, len=files.length; i<len; i++){
   var item = files[i],
    itempath = getLastCode(path)=='/' ? path+item : path+'/'+item; // 拼接路徑
   var st = fs.statSync(itempath);
   if( st.isFile() ){
    fs.unlinkSync(itempath);
    console.log( '刪除成功: '+itempath );
   }else if( st.isDirectory() ){
    // 當前是文件夾,則遞歸檢索
    rmDirAll( itempath );
   }
  }
  // 現在可以刪除文件夾
  fs.rmdir(path);
  console.log( '刪除成功: '+path );
 }
}
rmDirAll('./img');

則刪除時輸出的信息如下,先把內部的文件和文件夾刪除干凈,最后刪除 ‘./img':

刪除成功: ./img/1484234634801.png
刪除成功: ./img/1484234660592.png
刪除成功: ./img/gggg/est.txt
刪除成功: ./img/gggg
刪除成功: ./img/test.png
刪除成功: ./img

當然,你也可以試著實現這樣的程序:

  1. 刪除path內部所有的內容,同時能保留下path目錄

  2. 只刪除文件,將所有的空文件夾保留下來

  3. 將內部所有的文件都移動到path的根目錄下,并刪除空文件夾

關于node.js中怎么對文件進行操作就分享到這里了,希望以上內容可以對大家有一定的幫助,可以學到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

崇义县| 循化| 双牌县| 扎赉特旗| 揭东县| 屏东县| 克什克腾旗| 郴州市| 萍乡市| 山西省| 武清区| 玉林市| 营口市| 兴义市| 杨浦区| 武平县| 历史| 罗源县| 定日县| 天镇县| 华安县| 大悟县| 阳江市| 惠来县| 焦作市| 桂林市| 固原市| 平山县| 玛沁县| 宁河县| 宁蒗| 康乐县| 昭通市| 岫岩| 扎囊县| 永安市| 南宫市| 青铜峡市| 吴江市| 湟中县| 东兴市|