1、什么是fs文件系统模块

【解释】: fs文件系统模块是Node.js官方提供的,用来操作文件的模块,它提供了一系列的方法和属性,用来满足用户对文件操作的基本需求。

【基本使用】:

安装node后直接导入

const fs = require ('fs')

2、读取指定文件的内容

1、fs.readFile()的语法格式

【语法】:

fs.readFile(path, [,options], callback)

【参数解读】:

  • 参数1:必选参数,表示读取文件的路径
  • 参数2:可选参数,表示可选参数,表示通过什么方式的编码来读取文件
  • 参数3:必选参数,回调函数,通过回调函数获取文件内容

2、fs.readFile()读取文件内容

【代码示例】:

// 1、导入fs模块
const fs = require('fs');
// 2、使用fs.readfiles()方法读取指定文件的内容
/**
 * 参数1:读取文件的存放路径
 * 参数2:读取文件的时候采用的编码格式
 * 参数3:回调函数,参数1表示读取失败的结果 参数2 表示读取成功的结果
 */
fs.readFile('./files/11.txt', 'utf-8', function (err, dataStr) {
    // 文件信息读取成功的时候err返回值是null
    console.log(err);
    console.log('------------------');
    console.log(dataStr);
})

3、判断文件是否读取成功

【代码示例】:

// 1、导入fs模块
const fs = require('fs');
// 2、使用fs.readfiles()方法读取指定文件的内容
/**
 * 参数1:读取文件的存放路径
 * 参数2:读取文件的时候采用的编码格式
 * 参数3:回调函数,参数1表示读取失败的结果 参数2 表示读取成功的结果
 */
fs.readFile('./files/11.txt', 'utf-8', function (err, dataStr) {
    if (err) {
        // 读取文件失败,返回错误信息
        return console.log('读取文件失败!!' + err.message);;
    } else {
        // 读取文件成功,打印文件信息
        console.log('读取文件成功:'+dataStr);
    }
}) 

3、向指定文件写入内容

1、fs.writeFile()的语法格式

【语法】:

fs.writeFile(filePath, data, [,option] callback)

【参数解读】:

  • 参数1:必选参数,指定文件字符串路径,表示文件的存放路径
  • 参数2:必选参数,表示要写入的内容
  • 参数3:可选参数,表示用什么方式写入内容,默认是utf-8
  • 参数4:必选参数,表示文件写入之后的回调函数。

2、fs.writeFile()写入文件

【代码示例】:

// 1、导入fs模块
const fs = require('fs')
// 2、使用fs.writeFile()方法,向文件中写入内容
/**
 * 参数1:写入信息的路径
 * 参数2:要写入的内容
 * 参数3:回调函数
 * 参数4:编码格式,默认是utf-8,可以省略不写
 */
fs.writeFile('./files/2.txt', '张三', function (err) {
    // 如果文件写入成功,err返回null
    // 如果文件写入失败,则返回一个错误对象
    console.log(err);
})

3、fs.writeFile()判断写入是否成功

// 1、导入fs模块
const fs = require('fs')
// 2、使用fs.writeFile()方法,向文件中写入内容
/**
 * 参数1:写入信息的路径
 * 参数2:要写入的内容
 * 参数3:回调函数
 * 参数4:编码格式,默认是utf-8,可以省略不写
 */
fs.writeFile('./files/2.txt', '张三', function (err) {
    // 如果文件写入成功,err返回null
    // 如果文件写入失败,则返回一个错误对象
    if (err) {
        return console.log('文件写入失败' + err.message);
    } else {
        console.log('文件写入成功!!');
    }

})

4、写入文件和读取文件综合应用

【需求】:

  • 使用 fs 文件系统模块,将成绩.txt文件中的考试数据,整理到成绩-ok.txt文件中。
  • 整理前,成绩.txt文件中的数据格式如下:
  • 小红=100…
  • 整理后的格式如下:
  • 小红:100…

【案例分析】:

  • 导入fs文件模块
  • 读取文件中的旧数据
  • 判断是否读取成功
  • 数据格式处理
  • 写入新的文件中

【代码实现】:

// 1、导入fs文件系统模块
const fs = require("fs");
// 2、读取成绩信息
fs.readFile('./files/成绩.txt', 'utf-8', function (err, data) {
    // 判断成绩是否读取成功
    if (err) {
        // 读取失败,返回错误信息
        return console.log('读取成绩失败!!' + err.message);
    } else {
        // 读取成功。返回读取的数据
        // 将成绩的数据按照空格分隔
        const arrOld = data.split(' ')
        // 对分隔后的数组,对每一项数据进行字符串替换操作
        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);
            } else {
                // 写入成功
                console.log('写入文件成功!!');
            }
        })
    }
})

5、fs模块-路径动态拼接问题

【问题描述】: 在使用 fs 模块操作文件时,如果提供的操作路径是以 ./ 或 …/ 开头的相对路径时,很容易出现路径动态拼接错误的问题。

【原因】: 代码在运行的时候,会以执行 node 命令时所处的目录,动态拼接出被操作文件的完整路径。

【解决方案】:

在使用 fs 模块操作文件时,直接提供完整的路径,不要提供 ./ 或 …/ 开头的相对路径,从而防止路径动态拼接的问题。

const fs = require('fs');
// __dirname表示当前文件的目录
fs.readFile(__dirname + '/files/11.txt', 'utf-8', function (err, data) {
    if (err) {
        return err.message;
    } else {
        console.log(data);
    }
})

总结

本篇文章就到这里了,希望能够给你带来帮助,也希望您能够多多关注阿兔在线工具的更多内容!          

点赞(0)

微信公众账号

微信扫一扫加关注

发表
评论
返回
顶部