>首页> IT >

带你使用Node读写txt和Excel文件

时间:2022-10-24 20:59:19       来源:转载

前端有时要处理一些数据(比如多语言文件内容的替换),我们不要傻乎乎地干这种重复枯燥又浪费时间的ctrl C+ ctrl V的工作,这种事情交给计算机做再合适不过了。【相关教程推荐:nodejs视频教程】

这篇文章只是简单地介绍前端如何通过Node来读取Exceltxt文件中的数据,然后写入到txt文件中的方法。首先给出文件的内容:test.txt文件只有一句话(我是txt文件的内容);test.xlsx文件中,具体如图所示:


【资料图】

读取txt文件

废话不多说,show me your code:

/** 引入Node的文件模块 */const fs = require(\"fs\");/** 获取要读取的文件的路径 */const path = \"./test.txt\"; /** 判断该文件是否存在 */const isExist = fs.existsSync(path); /** 读取文件的内容 */const data = isExist ? fs.readFileSync(path, \"utf-8\") : \"\";/** 测试读取 */console.log(\"test.txt的内容:\", data)  // test.txt的内容: 我是txt文件的内容
登录后复制

写入txt文件

/** 引入Node的文件模块 */const fs = require(\"fs\");/** 测试写入 */fs.writeFile(\"write.txt\", \"测试写入\", (err, data) => {    if (err) throw err;});
登录后复制

这里我们并不需要主动创建write.txt,代码会自动判断这个文件是否存在,如果不存在则自动创建该文件。注意,如果该文件存在,调用writeFile(该方法的完整使用可以参考这)时,将会用新的内容替换掉原有的内容。运行如下:

还有一种是追加操作,就是在原来的基础上添加数据:

/** 引入Node的文件模块 */const fs = require(\"fs\");/** 测试写入 */fs.appendFile(\"write.txt\", \"测试写入\", (err, data) => {    if (err) throw err;});
登录后复制

运行如下:

提示:这里需要注意的是,当我们向文件中直接写入的是JS对象的时候,结果并不符合我们的预期:

/** 引入Node的文件模块 */const fs = require(\"fs\");const obj = {    name: \"cc\",    age: 15}/** 测试写入 */fs.writeFile(\"write.txt\", obj, (err, data) => {    if (err) throw err;});
登录后复制

运行结果:

这时可以通过JSON.stringify()字符串化对象,即可:

/** 引入Node的文件模块 */const fs = require(\"fs\");const obj = {    name: \"cc\",    age: 15}/** 测试写入 */fs.writeFile(\"write.txt\", JSON.stringify(obj), (err, data) => {    if (err) throw err;});
登录后复制

结果如下:

为了使写入格式更好看一点,可以往JSON.stringify()方法中添加一些参数(JSON.stringify()方法的使用可以参考这),比如添加一个Tab缩进:

/** 引入Node的文件模块 */const fs = require(\"fs\");const obj = {    name: \"cc\",    age: 15}/** 测试写入 */fs.writeFile(\"write.txt\", JSON.stringify(obj, null, \"\\t\"), (err, data) => {    if (err) throw err;});
登录后复制

读取Excel文件

/** 引入Node的文件模块 */const fs = require(\"fs\");/** 引入Excel文件处理模块(若没安装,安装一下即可) */const xlsx = require(\"node-xlsx\");/** 解析excel文档 */const sheets = xlsx.parse(\"./test.xlsx\");console.log(\"sheets data:\", sheets)
登录后复制

可以看到输出的结果:

解析后的内容sheets是一个数组,每一个sheet表以一个对象{ name: \"xxx\", data: [...]}的形式作为数组的元素。 完整的样子如下:

/** sheets的完整内容 */[{    name: \"Sheet1\", /** sheet页名称 */    data: [        [\"name\", \"age\"], /** 第一个元素为表头 */        [\"Tom\", 11],        [\"Bob\", 13]    ]}, {    name: \"Sheet2\", /** sheet页名称 */    data: [        [\"animal\", \"legs\"], /** 第一个元素为表头 */        [\"cat\", 4],        [\"dog\", 4],        [\"duck\", 2]    ]}]
登录后复制

写入Excel文件

从上面我们知道了读取Excel后的文件的格式,那么写入也只要按照这种格式构建好,再调用函数写入就行啦~

/** 引入Node的文件模块 */const fs = require(\"fs\");/** 引入Excel文件处理模块 */const xlsx = require(\"node-xlsx\");/** 构建数据 */const myData = [{    name: \"我的表格1\",    data: [        [\"name\", \"age\"],        [\"Tom\", 11],        [\"Bob\", 13]    ]}, {    name: \"我的表格2\",    data: [        [\"animal\", \"legs\"],        [\"cat\", 4],        [\"dog\", 4],        [\"duck\", 2]    ]}]/** 构建数据流 */const buffer = xlsx.build(myData);/** 将数据写入write.xlsx */fs.writeFile(\"./write.xlsx\", buffer, err => {    if (err) {        throw err;    }});
登录后复制

同理,write.xlsx文件如果不存在的话也会自动创建。运行结果如下:

至此,我们都知道了读取以及写入文件的方法,接下来任你折腾,想干嘛就干嘛,可以愉快地玩数据了~

更多node相关知识,请访问:nodejs 教程!

以上就是带你使用Node读写txt和Excel文件的详细内容,更多请关注php中文网其它相关文章!

关键词: 文件处理 相关文章