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

 3113

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


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

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


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


读取txt文件

废话不多说,show me your code:

  1. /** 引入Node的文件模块 */
  2. const fs = require("fs");
  3.  
  4. /** 获取要读取的文件的路径 */
  5. const path = "./test.txt"; 
  6.  
  7. /** 判断该文件是否存在 */
  8. const isExist = fs.existsSync(path); 
  9.  
  10. /** 读取文件的内容 */
  11. const data = isExist ? fs.readFileSync(path, "utf-8") : "";
  12.  
  13. /** 测试读取 */
  14. console.log("test.txt的内容:", data)  // test.txt的内容: 我是txt文件的内容

写入txt文件

  1. /** 引入Node的文件模块 */
  2. const fs = require("fs");
  3.  
  4. /** 测试写入 */
  5. fs.writeFile("write.txt", "测试写入", (err, data) => {
  6.     if (err) throw err;
  7. });

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


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


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

  1. /** 引入Node的文件模块 */
  2. const fs = require("fs");
  3.  
  4. /** 测试写入 */
  5. fs.appendFile("write.txt", "测试写入", (err, data) => {
  6.     if (err) throw err;
  7. });

运行如下:


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


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

  1. /** 引入Node的文件模块 */
  2. const fs = require("fs");
  3.  
  4. const obj = {
  5.     name: 'cc',
  6.     age: 15
  7. }
  8.  
  9. /** 测试写入 */
  10. fs.writeFile("write.txt", obj, (err, data) => {
  11.     if (err) throw err;
  12. });

运行结果:


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


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

  1. /** 引入Node的文件模块 */
  2. const fs = require("fs");
  3.  
  4. const obj = {
  5.     name: 'cc',
  6.     age: 15
  7. }
  8.  
  9. /** 测试写入 */
  10. fs.writeFile("write.txt", JSON.stringify(obj), (err, data) => {
  11.     if (err) throw err;
  12. });

结果如下:


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


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

  1. /** 引入Node的文件模块 */
  2. const fs = require("fs");
  3.  
  4. const obj = {
  5.     name: 'cc',
  6.     age: 15
  7. }
  8.  
  9. /** 测试写入 */
  10. fs.writeFile("write.txt", JSON.stringify(obj, null, '\t'), (err, data) => {
  11.     if (err) throw err;
  12. });


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


读取Excel文件

  1. /** 引入Node的文件模块 */
  2. const fs = require("fs");
  3.  
  4. /** 引入Excel文件处理模块(若没安装,安装一下即可) */
  5. const xlsx = require('node-xlsx');
  6.  
  7. /** 解析excel文档 */
  8. const sheets = xlsx.parse('./test.xlsx');
  9. console.log("sheets data:", sheets)

可以看到输出的结果:


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


解析后的内容sheets是一个数组,每一个sheet表以一个对象{ name: 'xxx', data: [...]}的形式作为数组的元素。

完整的样子如下:

  1. /** sheets的完整内容 */
  2. [{
  3.     name: 'Sheet1', /** sheet页名称 */
  4.     data: [
  5.         ['name', 'age'], /** 第一个元素为表头 */
  6.         ['Tom', 11],
  7.         ['Bob', 13]
  8.     ]
  9. }, {
  10.     name: 'Sheet2', /** sheet页名称 */
  11.     data: [
  12.         ['animal', 'legs'], /** 第一个元素为表头 */
  13.         ['cat', 4],
  14.         ['dog', 4],
  15.         ['duck', 2]
  16.     ]
  17. }]

写入Excel文件

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

  1. /** 引入Node的文件模块 */
  2. const fs = require("fs");
  3.  
  4. /** 引入Excel文件处理模块 */
  5. const xlsx = require('node-xlsx');
  6.  
  7. /** 构建数据 */
  8. const myData = [{
  9.     name: '我的表格1',
  10.     data: [
  11.         ['name', 'age'],
  12.         ['Tom', 11],
  13.         ['Bob', 13]
  14.     ]
  15. }, {
  16.     name: '我的表格2',
  17.     data: [
  18.         ['animal', 'legs'],
  19.         ['cat', 4],
  20.         ['dog', 4],
  21.         ['duck', 2]
  22.     ]
  23. }]
  24.  
  25. /** 构建数据流 */
  26. const buffer = xlsx.build(myData);
  27.  
  28. /** 将数据写入write.xlsx */
  29. fs.writeFile('./write.xlsx', buffer, err => {
  30.     if (err) {
  31.         throw err;
  32.     }
  33. });

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


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


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


本文网址:https://www.zztuku.com/detail-13238.html
站长图库 - 带你使用Node读写txt和Excel文件
申明:本文转载于《CSDN》,如有侵犯,请 联系我们 删除。

评论(0)条

您还没有登录,请 登录 后发表评论!

提示:请勿发布广告垃圾评论,否则封号处理!!

    编辑推荐