位置: IT常识 - 正文

Node.js——文件模块和路径模块(读写文件,处理路径)(node 文件)

编辑:rootadmin
Node.js——文件模块和路径模块(读写文件,处理路径)

推荐整理分享Node.js——文件模块和路径模块(读写文件,处理路径)(node 文件),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:node运行js文件,node.js 文件操作,node运行js文件,nodejs filereader,node.js 文件下载,node.js 文件操作,node.js 文件操作,node.js 文件下载,内容如对您有帮助,希望把文章链接给更多的朋友!

个人简介

👀个人主页: 前端杂货铺 🙋‍♂️学习方向: 主攻前端方向,也会涉及到服务端 📃个人状态: 在校大学生一枚,已拿 offer(秋招) 🥇推荐学习:🍍前端面试宝典 🍉Vue2 🍋Vue3 🍓Vue2&Vue3项目实战 🥝Node.js 🌕个人推广:每篇文章最下方都有加入方式,旨在交流学习&资源分享,快加入进来吧

Node.js系列文章目录内容参考链接Node.js(一)初识 Node.js文章目录Node.js系列文章目录一、fs 文件系统模块1、读取指定文件2、写入指定文件3、整理成绩案例4、处理路径二、path 路径模块1、path.join() 路径拼接2、path.basename() 解析文件名3、path.extname() 获取扩展名一、fs 文件系统模块

fs 模块 是 Node.js 官方提供的、用来 操作文件 的模块。它提供了一系列的方法和属性,用来满足用户对文件的操作要求。

1、读取指定文件

fs.readFile():读取指定文件中的内容

参数 1:必选参数,字符串,表示文件的路径 参数 2:可选参数,表示以什么编码格式来读取文件 参数 3:必选参数,文件读取完成后,通过回调函数拿到读取的结果

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

示例1:读取 demo.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为错误对象,data为undefined】

示例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)})

2、写入指定文件

fs.writeFile():向指定的文件中写入内容

参数 1:必选参数,需要指定一个文件路径的字符串,表示文件的存放路径 参数 2:必选参数,表示要写入的内容 参数 3:可选参数,表示以什么格式写入文件内容,默认 utf-8 参数 4:必选参数,文件写入完成后的回调函数

fs.writeFile(file, data, [options], callback)

示例1:写入 demo.txt 文件

demo.txt 文件

// 该文件内容为空

app.js 文件

// 导入 fs 文件系统模块const fs = require('fs')// 写入文件内容fs.writeFile('../files/demo.txt', '这里是前端杂货铺', function(err, data) { if (err) { return console.log('写入文件失败', err.message) } console.log('文件写入成功')})

备注:若写入不存在的盘中,即文件写入失败,打印内容如下

3、整理成绩案例

示例:成绩的格式转换

Node.js——文件模块和路径模块(读写文件,处理路径)(node 文件)

转换前的成绩格式

转换后的成绩格式

文件格式如下

score.txt 文件

写入成绩内容杂货铺=100 张三=98 李四=95 王五=92

app.js 文件

导入需要的 fs 文件模块使用 fs.readFile() 方法,读取素材目录下的 score.txt 文件判断文件是否读取失败文件读取成功后,处理成绩数据将处理完成的成绩数据,调用 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('成绩写入成功') })})

4、处理路径

__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 路径模块

path 模块是 Node.js 官方提供的、用来处理路径的模块

1、path.join() 路径拼接

path.join():用来将多个路径判断拼接成一个完整的路径字符串

参数:…paths <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('文件读取成功')})

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

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

3、path.extname() 获取扩展名

path.extname():可以获取路径中的扩展名部分

参数:path <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

本文链接地址:https://www.jiuchutong.com/zhishi/300219.html 转载请保留说明!

上一篇:Python+ChatGPT制作一个AI实用百宝箱(python pyecharts)

下一篇:【蓝桥杯Web】第十四届蓝桥杯(Web 应用开发)模拟赛 1 期-职业院校组 | 精品题解(蓝桥杯b组2020)

  • 哪些资产损失向银行贷款
  • 初级税务师什么时候报名
  • 公司用的口罩放哪个科目
  • 出口货物丢失起诉谁
  • 免征增值税的个体户个税
  • 代理记账公司账本
  • 销项负数发票怎么做账
  • 购进货物用于在建工程要交增值税吗
  • 公司之间房产过户免税条件
  • 工程结算方式分为
  • 会计凭证如何填写
  • 仪器设备校验记录表
  • 承兑汇票转出
  • 银行汇票分几种
  • 保险摊销什么 时候开始
  • 失业养老保险如何办理
  • 收到发票冲预付账款摘要怎么写
  • 分支机构的企业所得税申报流程是什么
  • 企业拥有房产每年如何交税
  • 去年的税还能退吗
  • 出口退税审核系统疑点
  • 装修发票是什么发票
  • 电子发票可以做报销凭证吗
  • 其他应付款的会计英文
  • 办公室装修合同印花税怎么缴纳?
  • 生活中都交了哪些朋友
  • 免征增值税的会计处理方法有哪些
  • windows11怎么设置壁纸
  • 此windows副本不是正版影响电脑使用吗
  • 取得经营所得及其他所得交纳的所得税
  • bootice.exe
  • 如何使用linux服务器
  • php数组函数面试题
  • 简易计税方法的适用主体有
  • 建设项目的设计阶段分为
  • 商铺转让权是什么意思
  • 法国西南部城市
  • 比利牛斯山作为天然界限
  • 微信公众号php开发教程
  • javaweb实验一
  • vue 插槽详解
  • 开源ei
  • accubattery准确性
  • c语言 *指针
  • 代收款用什么会计科目
  • 加工费能直接抵税吗
  • 公司基本户可以异地开户吗
  • 年报中的利润表本月数需要填吗
  • 资产负债表坏账准备计入哪里科目
  • PostgreSQL教程(六):函数和操作符详解(2)
  • 投资性房地产成本模式转公允模式差额
  • 公司缴纳残保金的标准
  • 合同权利义务包含债务吗
  • 发票一般会失效几天
  • 暂估商品入库 后收到发票怎么做分录
  • 建筑工程劳务分包,工伤责任承担
  • 个体工商户注销代办
  • 彻底关闭windows10自动更新工具
  • xp系统硬盘管理
  • window10快捷键不能用
  • 安装win8.1一直卡着不动
  • 在linux系统中命令
  • jquery通过扩展select控件实现支持enter或focus选择的方法
  • 置顶句子怎么弄
  • 什么是馥芮白
  • 同一个文件夹中的文件可以同名吗
  • 很好的资源学习入口_android
  • unity3d性能优化工具
  • nodejs实现文件下载
  • 安卓view事件分发
  • super函数python
  • 税务电子发票怎么开
  • 湖北税务官方网
  • 重庆市电子发票样式
  • 1+征收率
  • 沈阳市地方税务局
  • 没有单位怎么交职工养老保险
  • 期初库存和期末库存是什么意思
  • 怎么查询购置税交了没有
  • 民办非企业需要办理税务登记吗
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设