Maison > Article > interface Web > Un article pour parler du module de fichier fs et du module path dans Node (analyse de cas)
Cet article utilise le cas de la lecture et de l'écriture de fichiers et des chemins de traitement pour en savoir plus sur le module de fichier fs et le module de chemin dans Node J'espère qu'il sera utile à tout le monde !
module fs est un module officiellement fourni par Node.js et utilisé pour exploiter des fichiers. Il fournit une série de méthodes et de propriétés pour répondre aux exigences des utilisateurs en matière d'opérations sur les fichiers. [Recommandations de didacticiel associées : Tutoriel vidéo Nodejs]
fs.readFile() : Lire le contenu du fichier spécifié
Paramètre 1 : paramètre requis, chaîne. , indiquant le chemin du fichier
Paramètre 2 : Paramètre facultatif, indiquant le format d'encodage pour lire le fichier
Paramètre 3 : Paramètre obligatoire, une fois la lecture du fichier terminée, le résultat de la lecture est obtenu via la fonction de rappel
fs.readFile(path, [options], callback)
Exemple 1 : Lire le fichier demo.txt
fichier demo.txt
'前端杂货铺'
fichier 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) })
Remarques : si le chemin est incorrect, c'est-à-dire .fichier La lecture échoue, et le contenu imprimé est le suivant [err est l'objet d'erreur, les données ne sont pas définies]
Exemple 2 : Déterminez si la lecture du fichier demo.txt a réussi
app.js file
// 导入 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) })
fs.writeFile() : Écrivez le contenu dans le fichier spécifié. fichier spécifié
Paramètre 1 : Paramètre obligatoire, vous devez spécifier une chaîne de chemin de fichier, indiquant le chemin de stockage du fichier
Paramètre 2 : Paramètre obligatoire, indiquant le contenu à écrire
Paramètre 3 : Paramètre facultatif, indiquant le format dans lequel écrire Entrez le contenu du fichier, la valeur par défaut est utf-8
Paramètre 4 : paramètre obligatoire, fonction de rappel une fois l'écriture du fichier terminée
fs.writeFile(file, data, [options], callback)
Exemple 1 : écriture du fichier demo.txt
Fichier demo.txt
// 该文件内容为空
fichier app.js
// 导入 fs 文件系统模块 const fs = require('fs') // 写入文件内容 fs.writeFile('../files/demo.txt', '这里是前端杂货铺', function(err, data) { if (err) { return console.log('写入文件失败', err.message) } console.log('文件写入成功') })
Remarque : si l'écriture sur un disque qui n'existe pas, c'est-à-dire que l'écriture du fichier échoue et le contenu imprimé est le suivant
Exemple : Conversion du format de note
Format de note avant la conversion
Format de note après conversion
Le dossier le format est le suivant
fichier .txt de partition
杂货铺=100 张三=98 李四=95 王五=92
fichier app.js
// 导入 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 : Indique le répertoire où se trouve le fichier actuel
Exemple : Écrivez le chemin relatif
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 教程!
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!