站長(zhǎng)資訊網(wǎng)
        最全最豐富的資訊網(wǎng)站

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

        本篇文章通過(guò)讀寫(xiě)文件和處理路徑的案例,來(lái)一起學(xué)習(xí)下Node中的fs文件模塊和path路徑模塊,希望對(duì)大家有所幫助!

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

        node.js極速入門(mén)課程:進(jìn)入學(xué)習(xí)

        一、fs 文件系統(tǒng)模塊

        fs 模塊 是 Node.js 官方提供的、用來(lái) 操作文件 的模塊。它提供了一系列的方法和屬性,用來(lái)滿足用戶對(duì)文件的操作要求。【相關(guān)教程推薦:nodejs視頻教程】

        1、讀取指定文件

        fs.readFile():讀取指定文件中的內(nèi)容

        參數(shù) 1:必選參數(shù),字符串,表示文件的路徑
        參數(shù) 2:可選參數(shù),表示以什么編碼格式來(lái)讀取文件
        參數(shù) 3:必選參數(shù),文件讀取完成后,通過(guò)回調(diào)函數(shù)拿到讀取的結(jié)果

        fs.readFile(path, [options], callback)
        登錄后復(fù)制

        示例1:讀取 demo.txt 文件

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

        demo.txt 文件

        '前端雜貨鋪'
        登錄后復(fù)制

        app.js 文件

        // 導(dǎo)入 fs 文件系統(tǒng)模塊 const fs = require('fs')  // 讀取文件 utf-8 為中文編碼格式 fs.readFile('../files/demo.txt', 'utf-8', function (err, data) {     console.log('err:', err)     console.log('data:', data) })
        登錄后復(fù)制

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

        備注:若寫(xiě)錯(cuò)路徑,即文件讀取失敗,打印內(nèi)容如下【err為錯(cuò)誤對(duì)象,data為undefined】

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

        示例2:判斷讀取 demo.txt 文件是否成功

        app.js 文件

        • 故意寫(xiě)錯(cuò)路徑,讀取失敗
        • 失敗的結(jié)果如下

        // 導(dǎo)入 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) })
        登錄后復(fù)制

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

        2、寫(xiě)入指定文件

        fs.writeFile():向指定的文件中寫(xiě)入內(nèi)容

        參數(shù) 1:必選參數(shù),需要指定一個(gè)文件路徑的字符串,表示文件的存放路徑
        參數(shù) 2:必選參數(shù),表示要寫(xiě)入的內(nèi)容
        參數(shù) 3:可選參數(shù),表示以什么格式寫(xiě)入文件內(nèi)容,默認(rèn) utf-8
        參數(shù) 4:必選參數(shù),文件寫(xiě)入完成后的回調(diào)函數(shù)

        fs.writeFile(file, data, [options], callback)
        登錄后復(fù)制

        示例1:寫(xiě)入 demo.txt 文件

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

        demo.txt 文件

        // 該文件內(nèi)容為空
        登錄后復(fù)制

        app.js 文件

        // 導(dǎo)入 fs 文件系統(tǒng)模塊 const fs = require('fs')  // 寫(xiě)入文件內(nèi)容 fs.writeFile('../files/demo.txt', '這里是前端雜貨鋪', function(err, data) {     if (err) {         return console.log('寫(xiě)入文件失敗', err.message)     }     console.log('文件寫(xiě)入成功') })
        登錄后復(fù)制

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

        備注:若寫(xiě)入不存在的盤(pán)中,即文件寫(xiě)入失敗,打印內(nèi)容如下

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

        3、整理成績(jī)案例

        示例:成績(jī)的格式轉(zhuǎn)換

        轉(zhuǎn)換前的成績(jī)格式

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

        轉(zhuǎn)換后的成績(jī)格式

        一文聊聊Node中的fs文件模塊和path路徑模塊(案例分析)
        文件格式如下

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

        score.txt 文件

        • 寫(xiě)入成績(jī)內(nèi)容

        雜貨鋪=100 張三=98 李四=95 王五=92
        登錄后復(fù)制

        app.js 文件

        • 導(dǎo)入需要的 fs 文件模塊
        • 使用 fs.readFile() 方法,讀取素材目錄下的 score.txt 文件
        • 判斷文件是否讀取失敗
        • 文件讀取成功后,處理成績(jī)數(shù)據(jù)
        • 將處理完成的成績(jī)數(shù)據(jù),調(diào)用 fs.writeFile() 方法,寫(xiě)入到新文件 newScore.txt 中

        // 導(dǎo)入 fs 文件系統(tǒng)模塊 const fs = require('fs')  // 寫(xiě)入文件內(nèi)容 fs.readFile('../files/score.txt', 'utf-8', function (err, data) {     // 判斷是否讀取成功     if (err) {         return console.log('讀取文件失敗' + err.message)     }     // 把成績(jī)按空格進(jìn)行分割     const arrOld = data.split(' ')     // 新數(shù)組的存放     const arrNew = []     // 循環(huán)分割后的數(shù)組 對(duì)每一項(xiàng)數(shù)據(jù) 進(jìn)行字符串的替換操作     arrOld.forEach(item => {         arrNew.push(item.replace('=', ':'))     })     // 把新數(shù)組中的每一項(xiàng)合并 得到新的字符串     const newStr = arrNew.join('rn')      // 寫(xiě)入新數(shù)據(jù)     fs.writeFile('../files/newScore.txt', newStr, function (err) {         if (err) {             return console.log('寫(xiě)入成績(jī)失敗' + err.message)         }         console.log('成績(jī)寫(xiě)入成功')     }) })
        登錄后復(fù)制

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

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

        4、處理路徑

        __dirname:表示當(dāng)前文件所處的目錄

        示例:寫(xiě)相對(duì)路徑

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

        const fs = require('fs')  fs.readFile('../files/score.txt', 'utf-8', function(err, data) {     if (err) {         return console.log('文件讀取失敗' + err.message)     }     console.log('文件讀取成功') })
        登錄后復(fù)制

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

        示例:使用 __dirname

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

        const fs = require('fs')  // 讀取文件 fs.readFile(__dirname + '/files/score.txt', 'utf-8', function(err, data) {     if (err) {         return console.log('文件讀取失敗' + err.message)     }     console.log('文件讀取成功') })
        登錄后復(fù)制

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

        二、path 路徑模塊

        path 模塊是 Node.js 官方提供的、用來(lái)處理路徑的模塊

        1、path.join() 路徑拼接

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

        參數(shù):…paths <string> 路徑片段的序列
        返回值:返回值 <string>

        path.join([...paths])
        登錄后復(fù)制

        示例:路徑拼接

        // 導(dǎo)入 path 模塊 const path = require('path') // ../ 會(huì)抵消前面的路徑 const pathStr = path.join('/a','/b/c', '../', './d', 'e') console.log(pathStr)
        登錄后復(fù)制

        一文聊聊Node中的fs文件模塊和path路徑模塊(案例分析)
        備注:涉及到路徑拼接的操作,都要使用 path.join() 方法進(jìn)行處理。不要直接用 + 進(jìn)行字符串拼接

        示例:使用 path 進(jìn)行路徑拼接

        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('文件讀取成功') })
        登錄后復(fù)制

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

        2、path.basename() 解析文件名

        path.basename():用來(lái)從路徑字符串中,將文件名解析出來(lái)

        參數(shù) 1:path 必選參數(shù),表示一個(gè)路徑的字符串
        參數(shù) 2:ext 可選參數(shù),表達(dá)文件擴(kuò)展名
        返回值:返回 表示路徑中的最后一部分

        path.basename(path, [ext])
        登錄后復(fù)制

        示例:解析路徑,去除擴(kuò)展名

        // 導(dǎo)入 path 模塊 const path = require('path') // 文件的存放路徑 const fpath = '/a/b/c/index.html'  // 將文件名解析出來(lái) const fullName = path.basename(fpath) console.log(fullName) // 輸出 index.html  // 去除擴(kuò)展名 const nameWithoutExt = path.basename(fpath, '.html')  console.log(nameWithoutExt) // 輸出 index
        登錄后復(fù)制

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

        3、path.extname() 獲取擴(kuò)展名

        path.extname():可以獲取路徑中的擴(kuò)展名部分

        參數(shù):path <string> 必選參數(shù),表示一個(gè)路徑的字符串
        返回值:返回 <string> 返回得到的擴(kuò)展名字符串

        path.extname(path)
        登錄后復(fù)制

        示例:獲取擴(kuò)展名

        // 導(dǎo)入 path 模塊 const path = require('path') // 文件的存放路徑 const fpath = '/a/b/c/index.html' // 獲取擴(kuò)展名 const fext = path.extname(fpath)  console.log(fext) // .html
        登錄后復(fù)制

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

        贊(0)
        分享到: 更多 (0)
        網(wǎng)站地圖   滬ICP備18035694號(hào)-2    滬公網(wǎng)安備31011702889846號(hào)
        主站蜘蛛池模板: 久久精品夜夜夜夜夜久久| 久久亚洲国产欧洲精品一| 国产精品久久一区二区三区| 人妻少妇看A偷人无码精品| 99久久久精品| 特级精品毛片免费观看| 久久精品国产亚洲AV不卡| 99国产精品私拍pans大尺度| 91国内外精品自在线播放| 午夜精品久久久久久毛片| 欧美成人精品网站播放 | 99久久精品免费看国产| 国内精品久久久久久99蜜桃| 亚洲∧v久久久无码精品| 亚洲精品成人片在线观看| 免费精品国自产拍在线播放| 精品久久久久中文字幕一区| 国产久爱免费精品视频| 91久久精品电影| 999国产精品视频| 8050免费午夜一级国产精品| 亚洲国产精品一区二区久久| 精品国产自在在线在线观看| 国产精品18久久久久久vr| 国产办公室秘书无码精品99| 久久精品国产亚洲AV香蕉| 精品无码AV无码免费专区| 久久99精品久久久久久动态图| 日韩精品人妻系列无码专区免费 | 黑人巨大精品欧美| 国产精品视频色拍拍| 精品无码久久久久国产| 熟女精品视频一区二区三区| 十八18禁国产精品www| 久久精品国产亚洲av麻豆小说| 久久狠狠高潮亚洲精品| 国产精品兄妹在线观看麻豆| 高清免费久久午夜精品| 精品久久香蕉国产线看观看亚洲| 国产精品视频一区二区三区| 91精品国产成人网在线观看|