ホームページ > 記事 > ウェブフロントエンド > Nodeのfsファイルモジュールとパスモジュールについて語る記事(事例分析)
この記事では、ファイルの読み書きとパスの処理を例に、Node の fs ファイル モジュールとパス モジュールについて説明します。
fs モジュール は Node. js ファイル操作用に公式に提供されたモジュール。ファイル操作のユーザー要件を満たす一連のメソッドとプロパティを提供します。 [関連チュートリアルの推奨事項: nodejs ビデオ チュートリアル ]
##fs.readFile (): 指定されたファイルの内容を読み取ります。
パラメータ 1: ファイルのパスを示す必須パラメータ、文字列です。パラメータ 2: エンコーディング形式を示すオプションのパラメータです。ファイルの読み取り
パラメータ 3: 必須パラメータ ファイルの読み取りが完了すると、コールバック関数を通じて読み取り結果が取得されますfs.readFile(path, [options], callback)
例 1: デモを読み取ります。 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 はエラー オブジェクト、データは未定義]
例 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) })
パラメータ 4: 必須パラメータ、ファイル書き込み完了後のコールバック関数
fs.writeFile(file, data, [options], callback)
例 1:demo.txt ファイルの作成
##demo.txt ファイル// 该文件内容为空
// 导入 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 王五=92app.js ファイル必要な fs ファイル モジュールをインポートします
ファイルの読み取りが成功したら、スコアを処理しますdata
完成したスコア データが処理されます。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('成绩写入成功') }) })
__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 模块是 Node.js 官方提供的、用来处理路径的模块
path.join():用来将多个路径判断拼接成一个完整的路径字符串
参数:…paths
<string></string>
路径片段的序列
返回值:返回值<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('文件读取成功') })
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
path.extname():可以获取路径中的扩展名部分
参数:
path <string></string>
必选参数,表示一个路径的字符串
返回值:返回<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相关知识,请访问:nodejs 教程!
以上がNodeのfsファイルモジュールとパスモジュールについて語る記事(事例分析)の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。