如何用Node实现读写文件操作,过程是什么
Admin 2022-11-12 群英技术资讯 561 次浏览
在这篇文章中我们来了解一下“如何用Node实现读写文件操作,过程是什么”,一些朋友可能会遇到这方面的问题,对此在下文小编向大家来讲解,内容详细,易于理解,希望大家阅读完这篇能有收获哦,有需要的朋友就往下看吧!
操作文件是服务端一个基础的功能,也是做后端开发的必备能力之一。操作文件主要包括读和写。而这些功能 Nodejs 都已经提供了对应的方法。只要调用就行了。
同步方法
const fs = require('fs')
fs.mkdirSync(`${__dirname}/雷猴`)
登录后复制
NodeJS
有一个文件模块,叫 fs
。对文件操作的话,必须先引入这个模块。
使用 fs.mkdirSync
方法可以创建一个文件夹。里面传入要创建的文件夹的名字即可。
__dirname
指的是当前文件所在文件夹的绝对路径。
异步创建
const fs = require('fs')
fs.mkdir(`${__dirname}/雷猴`, err => {
if (err) {
console.error(err)
}
})
登录后复制
使用 fs.mkdir
方法可以进行异步创建,第一个参数也是文件夹名称,第二个是回到函数,该函数里有一个 err
参数,可以返回错误信息。
创建完文件夹,本来是想讲 “删除文件夹” 的。但由于删除文件夹之前要清空里面所有文件,所以就把 删除文件 的用法放在前面讲。
删除文件分 同步 和 异步 两种方法。
同步 fs.unlinkSync
const fs = require('fs')
fs.unlinkSync(`${__dirname}/test.txt`);
登录后复制
fs.unlinkSync
里传入要删除的文件路径和文件名,即可删除指定文件。
异步 fs.unlink
const fs = require('fs')
fs.unlink(`${__dirname}/test.txt`, err => {
if (err) {
console.error(err)
}
})
登录后复制
fs.unlink
方法有2个参数,第一个参数是文件路径和文件名,第二个参数是监听删除失败的回调函数。
删除文件夹之前要清空目标文件夹里的所有文件。 可以使用 fs.unlinkSync
或 fs.unlink
删除文件。
同步
const fs = require('fs')
fs.rmdirSync(`${__dirname}/雷猴`)
登录后复制
异步
const fs = require('fs')
fs.rmdir(`${__dirname}/雷猴`, err => {
if (err) {
console.error(err)
}
})
登录后复制
和删除文件的用法差不多,删除文件夹的方法也有同步和异步,异步接受2个参数,第二个参数同样是监听报错的回调。
const fs = require('fs')
const content = ' 雷猴雷猴\n'
const opt = {
flag: 'a', // a:追加写入;w:覆盖写入
}
fs.writeFile('test.txt', content, opt, (err) => {
if (err) {
console.error(err)
}
})
登录后复制
fs.writeFile
方法可以将内容写入文件中。如果文件不存在,会自动创建文件。
fs.writeFile
参数说明:
const fs = require('fs')
fs.readFile('fileName', (err, data) => {
if (err) {
console.error(err)
return
}
// data 是二进制类型,需要转换成字符串
console.log(data.toString())
})
登录后复制
使用 fs.readFile
方法可以读取数据,第一个参数是文件名;第二个参数是回调,err
监听错误信息,data
是读取回来的数据。
需要注意的是,读取回来的 data
是一个二进制类型的数据,需要使用 toString()
方法转换成我们读得懂的数据。
const fs = require('fs')
const exist = fs.existsSync('fileName')
console.log(exist)
登录后复制
使用 fs.existsSync
方法可以检测指定文件是否存在,如果存在就返回 true
;否则返回 false
。
如果你使用 NodeJS
做后台,读写文件这块知识点是逃不过去的。它最常见的功能可以写日志,比如收集错误日志等。
日志我们也可以写在数据库里,不过不是所有电脑都装了相同的数据库。但如果你将日志写在一个文件中,文件的内容在别的电脑一般都能轻易打开。
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:mmqy2019@163.com进行举报,并提供相关证据,查实之后,将立刻删除涉嫌侵权内容。
猜你喜欢
这篇文章主要介绍了VUE+Canvas实现财神爷接元宝小游戏,需要的朋友可以参考下本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧
这篇文章主要为大家介绍了前端取消请求及取消重复请求方式,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
目录前言宏任务宏任务队列微任务微任务队列Event-Loop执行顺序结语前言首先我们要了解javascript是一个单线程的脚本语言,也就是说我们在执行代码的过程中不会出现同时进行两个进程(执行两段代码)。Javascript语言将任务的执行模式分成两种:同步(Synchronous)和异步(Asynchronous)
这篇文章主要为大家介绍了Vue 事件处理函数的绑定示例详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
通过前面的学习,我们可以顺利的在Vue中将数据源渲染到HTML的DOM元素中,但很多时候我们希望能控制数据源。也就是数据绑定,并且与其通讯。简单的说,怎么在Vue中实现数据的双向绑
成为群英会员,开启智能安全云计算之旅
立即注册Copyright © QY Network Company Ltd. All Rights Reserved. 2003-2020 群英 版权所有
增值电信经营许可证 : B1.B2-20140078 粤ICP备09006778号 域名注册商资质 粤 D3.1-20240008