node.js 学习入门(02 - fs系统模块)

简介: node.js 学习入门(02 - fs系统模块)

什么是 fs ?


Node.js 内置的fs模块就是文件系统模块,负责读写文件。

Node.js 文件系统(fs 模块)模块中的方法均有异步和同步版本,例如读取文件内容的函数有异步的 fs.readFile() 和同步的 fs.readFileSync()。

异步的方法函数最后一个参数为回调函数,回调函数的第一个参数包含了错误信息(error)。

建议大家使用异步方法,比起同步,异步方法性能更高,速度更快,而且没有阻塞。


读取文件内容

使用readFile方法读取文件的内容

// 1.导入 fs 模块,来操作文件
const fs = require('fs')
// 2.调用 fs.readFile() 方法读取文件
    // 参数一:读取文件的存放路径
    // 参数二:读取文件时候采用的编码格式,一般默认指定 utf8
    // 参数三:回调函数,拿到读取失败和成功的结果 err dataStr
    // 读取 files 文件夹下 1.txt 文件
fs.readFile('./files/1.txt', 'utf8', function (err,dataStr) {
    // 2.1打印失败的结果
        // 如果读取成功,则 err 的值为 null,dataStr 的值为 1.txt 里的内容
        // 如果读取失败,则 err 的值为 错误对象,dataStr 的值为 undefined
    console.log(err)
    console.log("-----")
    // 2.2打印成功的结果
    console.log(dataStr)
})

判断文件是否读取成功

// 导入 fs 模块,来操作文件
const fs = require('fs')
fs.readFile('./files/1.txt', 'utf8', function (err, dataStr) {
    // 判断 err 里的值是否为 null,如果不是则 err 转为 true,读取失败
    if (err) {
        return console.log("读取文件失败! "+ err.message)
    }
    console.log("读取文件成功,内容为:"+ dataStr)
})

写入文件内容

// 导入 fs 文件系统模块
const fs = require('fs')
// 调用 fs.writeFile() 方法,写入文件的内容
    // 参数一:表示文件的存放路径
    // 参数二:表示要写入的内容
    // 参数三:回调函数
fs.writeFile('./files/2.txt', '调用 fs.writeFile() 添加的内容', function (err) {
    // 2.1如果写入成功,则 err 的值等于 null
    // 2.2如果写入失败,则 err 的值等于一个 错误对象
    // 判断 err 里的值是否为 null,如果不是则 err 转为 true,读取失败
    if (err) {
        return console.log("文件写入失败!" + err.message)
    }
    console.log("文件写入成功!")
} )

处理路径问题

const fs = require('fs')
// 出现路径拼接错误的问题,是因为提供了 ./ 或 .// 开头的相对路径
// 如果要解决这个问题,可以直接提供一个完整的文件存放路径就行
// fs.readFile('./files/1.txt', function (err, data) {
//     if (err) {
//         return console.log("页面读取失败")
//     }
//     console.log("页面读取成功")
// })
// 移植性非常差,不利于维护(不推荐使用)
// fs.readFile('D:\\大华教育\\node.js\\js\\files\\1.txt', function (err, data) {
//     if (err) {
//         return console.log("页面读取失败")
//     }
//     console.log("页面读取成功")
// })
// __dirname 表示当前文件所处的目录(推荐使用)
// console.log(__dirname)
fs.readFile(__dirname + '/files/1.txt', function (err, data) {
    if (err) {
        return console.log("页面读取失败")
    }
    console.log("页面读取成功")
})

成绩整理案例

需要完成条件示例:

a3635883c3054a6ebcc5dbffb2d9c7f7.png

完成所需代码:

// 导入 fs 文件系统模块
const fs = require('fs')
// 调用 fs.readFile() 方法读取内容
fs.readFile('./files/成绩.txt', function (err, dataStr) {
    // 判断文件是否读取成功
    if (err) {
        return console.log("读取文件失败!"+err.message)
    }
    // console.log("读取文件成功!" + dataStr)
    // 4.1先把成绩的数据,按照空格进行分割
    const arrOld = dataStr.toString().split(' ')
    // 4.2循环分割后的数组,对每一项数据,进行字符串的替换操作
    const arrNew = []
    arrOld.forEach((item) => {
        arrNew.push(item.replace('=',':'))
    })
    // 4.3把新数组中的每一项,进行合并,得到一个新的字符串
    const newStr = arrNew.join('\r\n')
    console.log(newStr)
    // 5.调用 fs.writeFile() 方法,把处理完毕的成绩,写入到新文件中
    fs.writeFile('./files/新成绩.txt', newStr, function (err) {
        if (err) {
            return console.log("写入文件失败!"+err.message)
        }
        console.log("成绩写入成功!")
    })
})

以上就是 node.js 中 fs 的使用,不懂得也可以在评论区里问我,以后会持续添加一些新的功能,敬请关注。

相关文章
|
25天前
|
前端开发 机器人 API
前端大模型入门(一):用 js+langchain 构建基于 LLM 的应用
本文介绍了大语言模型(LLM)的HTTP API流式调用机制及其在前端的实现方法。通过流式调用,服务器可以逐步发送生成的文本内容,前端则实时处理并展示这些数据块,从而提升用户体验和实时性。文章详细讲解了如何使用`fetch`发起流式请求、处理响应流数据、逐步更新界面、处理中断和错误,以及优化用户交互。流式调用特别适用于聊天机器人、搜索建议等应用场景,能够显著减少用户的等待时间,增强交互性。
179 2
|
5天前
|
机器学习/深度学习 自然语言处理 前端开发
前端神经网络入门:Brain.js - 详细介绍和对比不同的实现 - CNN、RNN、DNN、FFNN -无需准备环境打开浏览器即可测试运行-支持WebGPU加速
本文介绍了如何使用 JavaScript 神经网络库 **Brain.js** 实现不同类型的神经网络,包括前馈神经网络(FFNN)、深度神经网络(DNN)和循环神经网络(RNN)。通过简单的示例和代码,帮助前端开发者快速入门并理解神经网络的基本概念。文章还对比了各类神经网络的特点和适用场景,并简要介绍了卷积神经网络(CNN)的替代方案。
|
5天前
|
移动开发 前端开发 JavaScript
前端实训,刚入门,我用原生技术(H5、C3、JS、JQ)手写【网易游戏】页面特效
于辰在大学期间带领团队参考网易游戏官网的部分游戏页面,开发了一系列前端实训作品。项目包括首页、2021校园招聘页面和明日之后游戏页面,涉及多种特效实现,如动态图片切换和人物聚合效果。作品源码已上传至CSDN,视频效果可在CSDN预览。
前端实训,刚入门,我用原生技术(H5、C3、JS、JQ)手写【网易游戏】页面特效
|
13天前
|
监控 前端开发 JavaScript
React 静态网站生成工具 Next.js 入门指南
【10月更文挑战第20天】Next.js 是一个基于 React 的服务器端渲染框架,由 Vercel 开发。本文从基础概念出发,逐步探讨 Next.js 的常见问题、易错点及解决方法,并通过具体代码示例进行说明,帮助开发者快速构建高性能的 Web 应用。
40 10
|
11天前
|
数据采集 存储 JavaScript
如何使用Puppeteer和Node.js爬取大学招生数据:入门指南
本文介绍了如何使用Puppeteer和Node.js爬取大学招生数据,并通过代理IP提升爬取的稳定性和效率。Puppeteer作为一个强大的Node.js库,能够模拟真实浏览器访问,支持JavaScript渲染,适合复杂的爬取任务。文章详细讲解了安装Puppeteer、配置代理IP、实现爬虫代码的步骤,并提供了代码示例。此外,还给出了注意事项和优化建议,帮助读者高效地抓取和分析招生数据。
如何使用Puppeteer和Node.js爬取大学招生数据:入门指南
|
4月前
|
JavaScript Java 测试技术
基于springboot+vue.js+uniapp的客户关系管理系统附带文章源码部署视频讲解等
基于springboot+vue.js+uniapp的客户关系管理系统附带文章源码部署视频讲解等
92 2
|
4月前
|
JavaScript Java 测试技术
基于springboot+vue.js+uniapp的小区物流配送系统附带文章源码部署视频讲解等
基于springboot+vue.js+uniapp的小区物流配送系统附带文章源码部署视频讲解等
114 4
|
4月前
|
JavaScript Java 测试技术
基于springboot+vue.js+uniapp的宠物援助平台附带文章源码部署视频讲解等
基于springboot+vue.js+uniapp的宠物援助平台附带文章源码部署视频讲解等
80 4
|
4月前
|
JavaScript Java 测试技术
基于springboot+vue.js+uniapp的宠物交易平台附带文章源码部署视频讲解等
基于springboot+vue.js+uniapp的宠物交易平台附带文章源码部署视频讲解等
71 4
|
4月前
|
JavaScript Java 测试技术
基于springboot+vue.js+uniapp的大学生入伍人员管理系统附带文章源码部署视频讲解等
基于springboot+vue.js+uniapp的大学生入伍人员管理系统附带文章源码部署视频讲解等
91 4