一文聊聊Node中的fs檔案模組和path路徑模組(案例分析)

2022-11-18 22:00:43
本篇文章通過讀寫檔案和處理路徑的案例,來一起學習下中的fs檔案模組和path路徑模組,希望對大家有所幫助!

node.js極速入門課程:進入學習

一、fs 檔案系統模組

fs 模組 是 Node.js 官方提供的、用來 操作檔案 的模組。它提供了一系列的方法和屬性,用來滿足使用者對檔案的操作要求。【相關教學推薦:】

1、讀取指定檔案

fs.readFile():讀取指定檔案中的內容

引數 1:必選引數,字串,表示檔案的路徑
引數 2:可選引數,表示以什麼編碼格式來讀取檔案
引數 3:必選引數,檔案讀取完成後,通過回撥函數拿到讀取的結果

fs.readFile(path, [options], callback)
登入後複製

範例1:讀取 demo.txt 檔案

在這裡插入圖片描述

demo.txt 檔案

'前端雜貨鋪'
登入後複製

app.js 檔案

// 匯入 fs 檔案系統模組
const fs = require('fs')

// 讀取檔案 utf-8 為中文編碼格式
fs.readFile('../files/demo.txt', 'utf-8', function (err, data) {
    console.log('err:', err)
    console.log('data:', data)
})
登入後複製

在這裡插入圖片描述

備註:若寫錯路徑,即檔案讀取失敗,列印內容如下【err為錯誤物件,data為undefined】

在這裡插入圖片描述

範例2:判斷讀取 demo.txt 檔案是否成功

app.js 檔案

  • 故意寫錯路徑,讀取失敗
  • 失敗的結果如下
// 匯入 fs 模組
const fs = require('fs')

// 讀取檔案
fs.readFile('../files/demo1.txt', 'utf-8', function (err, data) {
    if(err) {
        return console.log('讀取檔案失敗', err.message)
    }
    console.log('data:', data)
})
登入後複製

在這裡插入圖片描述

2、寫入指定檔案

fs.writeFile():向指定的檔案中寫入內容

引數 1:必選引數,需要指定一個檔案路徑的字串,表示檔案的存放路徑
引數 2:必選引數,表示要寫入的內容
引數 3:可選引數,表示以什麼格式寫入檔案內容,預設 utf-8
引數 4:必選引數,檔案寫入完成後的回撥函數

fs.writeFile(file, data, [options], callback)
登入後複製

範例1:寫入 demo.txt 檔案

在這裡插入圖片描述

demo.txt 檔案

// 該檔案內容為空
登入後複製

app.js 檔案

// 匯入 fs 檔案系統模組
const fs = require('fs')

// 寫入檔案內容
fs.writeFile('../files/demo.txt', '這裡是前端雜貨鋪', function(err, data) {
    if (err) {
        return console.log('寫入檔案失敗', err.message)
    }
    console.log('檔案寫入成功')
})
登入後複製

在這裡插入圖片描述

備註:若寫入不存在的盤中,即檔案寫入失敗,列印內容如下

在這裡插入圖片描述

3、整理成績案例

範例:成績的格式轉換

轉換前的成績格式

在這裡插入圖片描述

轉換後的成績格式

在這裡插入圖片描述
檔案格式如下

在這裡插入圖片描述

score.txt 檔案

  • 寫入成績內容
雜貨鋪=100 張三=98 李四=95 王五=92
登入後複製

app.js 檔案

  • 匯入需要的 fs 檔案模組
  • 使用 fs.readFile() 方法,讀取素材目錄下的 score.txt 檔案
  • 判斷檔案是否讀取失敗
  • 檔案讀取成功後,處理成績資料
  • 將處理完成的成績資料,呼叫 fs.writeFile() 方法,寫入到新檔案 newScore.txt 中
// 匯入 fs 檔案系統模組
const fs = require('fs')

// 寫入檔案內容
fs.readFile('../files/score.txt', 'utf-8', function (err, data) {
    // 判斷是否讀取成功
    if (err) {
        return console.log('讀取檔案失敗' + err.message)
    }
    // 把成績按空格進行分割
    const arrOld = data.split(' ')
    // 新陣列的存放
    const arrNew = []
    // 迴圈分割後的陣列 對每一項資料 進行字串的替換操作
    arrOld.forEach(item => {
        arrNew.push(item.replace('=', ':'))
    })
    // 把新陣列中的每一項合併 得到新的字串
    const newStr = arrNew.join('\r\n')

    // 寫入新資料
    fs.writeFile('../files/newScore.txt', newStr, function (err) {
        if (err) {
            return console.log('寫入成績失敗' + err.message)
        }
        console.log('成績寫入成功')
    })
})
登入後複製

在這裡插入圖片描述

在這裡插入圖片描述

4、處理路徑

__dirname:表示當前檔案所處的目錄

範例:寫相對路徑

在這裡插入圖片描述

const fs = require('fs')

fs.readFile('../files/score.txt', 'utf-8', function(err, data) {
    if (err) {
        return console.log('檔案讀取失敗' + err.message)
    }
    console.log('檔案讀取成功')
})
登入後複製

在這裡插入圖片描述

範例:使用 __dirname

在這裡插入圖片描述

const fs = require('fs')

// 讀取檔案
fs.readFile(__dirname + '/files/score.txt', 'utf-8', function(err, data) {
    if (err) {
        return console.log('檔案讀取失敗' + err.message)
    }
    console.log('檔案讀取成功')
})
登入後複製

在這裡插入圖片描述

二、path 路徑模組

path 模組是 Node.js 官方提供的、用來處理路徑的模組

1、path.join() 路徑拼接

path.join():用來將多個路徑判斷拼接成一個完整的路徑字串

引數:…paths <string> 路徑片段的序列
返回值:返回值 <string>

path.join([...paths])
登入後複製

範例:路徑拼接

// 匯入 path 模組
const path = require('path')
// ../ 會抵消前面的路徑
const pathStr = path.join('/a','/b/c', '../', './d', 'e')
console.log(pathStr)
登入後複製

在這裡插入圖片描述
備註:涉及到路徑拼接的操作,都要使用 path.join() 方法進行處理。不要直接用 + 進行字串拼接

範例:使用 path 進行路徑拼接

const fs = require('fs')
const path = require('path')

// 檔案讀取
fs.readFile(path.join(__dirname, '/files/score.txt'), 'utf-8', function(err, data) {
    if (err) {
        return console.log('檔案讀取失敗', err.message)
    }
    console.log('檔案讀取成功')
})
登入後複製

在這裡插入圖片描述

2、path.basename() 解析檔名

path.basename():用來從路徑字串中,將檔名解析出來

引數 1:path 必選引數,表示一個路徑的字串
引數 2:ext 可選引數,表達副檔名
返回值:返回 表示路徑中的最後一部分

path.basename(path, [ext])
登入後複製

範例:解析路徑,去除擴充套件名

// 匯入 path 模組
const path = require('path')
// 檔案的存放路徑
const fpath = '/a/b/c/index.html'

// 將檔名解析出來
const fullName = path.basename(fpath)
console.log(fullName) // 輸出 index.html

// 去除擴充套件名
const nameWithoutExt = path.basename(fpath, '.html')

console.log(nameWithoutExt) // 輸出 index
登入後複製

在這裡插入圖片描述

3、path.extname() 獲取擴充套件名

path.extname():可以獲取路徑中的擴充套件名部分

引數:path <string> 必選引數,表示一個路徑的字串
返回值:返回 <string> 返回得到的擴充套件名字串

path.extname(path)
登入後複製

範例:獲取擴充套件名

// 匯入 path 模組
const path = require('path')
// 檔案的存放路徑
const fpath = '/a/b/c/index.html'
// 獲取擴充套件名
const fext = path.extname(fpath)

console.log(fext) // .html
登入後複製

在這裡插入圖片描述

更多node相關知識,請存取:!

以上就是一文聊聊Node中的fs檔案模組和path路徑模組(案例分析)的詳細內容,更多請關注TW511.COM其它相關文章!