今天小编给大家分享一下如何使用Node读写txt和Excel文件的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。
首先给出文件的内容:test.txt文件只有一句话(我是txt文件的内容);test.xlsx文件中,具体如图所示:
读取txt文件
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文件
const fs = require("fs");fs.writeFile("write.txt", "测试写入", (err, data) => { if (err) throw err;});
这里我们并不需要主动创建write.txt
,代码会自动判断这个文件是否存在,如果不存在则自动创建该文件。注意,如果该文件存在,调用writeFile
(该方法的完整使用可以参考这)时,将会用新的内容替换掉原有的内容。运行如下:
还有一种是追加操作,就是在原来的基础上添加数据:
const fs = require("fs");fs.appendFile("write.txt", "测试写入", (err, data) => { if (err) throw err;});
运行如下:
提示:这里需要注意的是,当我们向文件中直接写入的是JS对象的时候,结果并不符合我们的预期:
const fs = require("fs");const obj = { name: 'cc', age: 15}fs.writeFile("write.txt", obj, (err, data) => { if (err) throw err;});
运行结果:
这时可以通过JSON.stringify()
字符串化对象,即可:
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
缩进:
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文件
const fs = require("fs");const xlsx = require('node-xlsx');const sheets = xlsx.parse('./test.xlsx');console.log("sheets data:", sheets)
可以看到输出的结果:
解析后的内容sheets
是一个数组,每一个sheet表以一个对象{ name: 'xxx', data: [...]}
的形式作为数组的元素。
完整的样子如下:
[{ name: 'Sheet1', data: [ ['name', 'age'], ['Tom', 11], ['Bob', 13] ]}, { name: 'Sheet2', data: [ ['animal', 'legs'], ['cat', 4], ['dog', 4], ['duck', 2] ]}]
写入Excel文件
从上面我们知道了读取Excel
后的文件的格式,那么写入也只要按照这种格式构建好,再调用函数写入就行啦~
const fs = require("fs");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);fs.writeFile('./write.xlsx', buffer, err => { if (err) { throw err; }});
同理,write.xlsx
文件如果不存在的话也会自动创建。运行结果如下:
以上就是“如何使用Node读写txt和Excel文件”这篇文章的所有内容,感谢各位的阅读!相信大家阅读完这篇文章都有很大的收获,小编每天都会为大家更新不同的知识,如果还想学习更多的知识,请关注编程网行业资讯频道。