Node读写txt和Excel格式文件怎样做?
Admin 2022-11-29 群英技术资讯 1004 次浏览
今天小编跟大家讲解下有关“Node读写txt和Excel格式文件怎样做?”的内容 ,相信小伙伴们对这个话题应该有所关注吧,小编也收集到了相关资料,希望小伙伴们看了有所帮助。前端有时要处理一些数据(比如多语言文件内容的替换),我们不要傻乎乎地干这种重复枯燥又浪费时间的ctrl C+ ctrl V的工作,这种事情交给计算机做再合适不过了。
这篇文章只是简单地介绍前端如何通过Node来读取Excel或txt文件中的数据,然后写入到txt文件中的方法。首先给出文件的内容:test.txt文件只有一句话(我是txt文件的内容);test.xlsx文件中,具体如图所示:



废话不多说,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文件的内容 登录后复制 /** 引入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;
}); 登录后复制 
/** 引入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后的文件的格式,那么写入也只要按照这种格式构建好,再调用函数写入就行啦~
/** 引入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文件如果不存在的话也会自动创建。运行结果如下:

至此,我们都知道了读取以及写入文件的方法,接下来任你折腾,想干嘛就干嘛,可以愉快地玩数据了~
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:mmqy2019@163.com进行举报,并提供相关证据,查实之后,将立刻删除涉嫌侵权内容。
猜你喜欢
这篇文章主要介绍了VUE实现一个简单的学生信息管理系统,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
在vue3版本中,引入了一个新的函数,叫做setup。本文将通过实例为大家详细讲讲Vue3.2中setup语法糖的使用,感兴趣的小伙伴可以了解一下
这篇文章主要给大家介绍的是keep-alive组件的缓存原理,很多对于keepalive缓存组件的用法可能比较熟练,但是其缓存原理并不是很清楚,对此下面会从源码角度与大家一起探讨一下keep-alive组件的缓存原理。
这篇文章主要介绍了Vue3内置组件Teleport使用方法,Teleport是Vue 3.0 新增的一个内置组件,主要是为了解决一些特殊场景下模态对话框组件、组件的渲染,带着些许的了解一起走进下面文章的详细内容吧
简介Diffie-Hellman(简称DH)是密钥交换算法之一,它的作用是保证通信双方在非安全的信道中安全地交换密钥。目前DH最重要的应用场景之一,就是在HTTPS的握手阶段,客户端、服务端利用DH算法交换对称密钥。下面会先简单介绍DH的数理基础,然后举例说明如何在nodejs中使用DH相关的API。数论基础要理解DH算法,需要掌握一定的数论基础。感兴趣的可以进一步研究推导过程,或者直接记
成为群英会员,开启智能安全云计算之旅
立即注册关注或联系群英网络
7x24小时售前:400-678-4567
7x24小时售后:0668-2555666
24小时QQ客服
群英微信公众号
CNNIC域名投诉举报处理平台
服务电话:010-58813000
服务邮箱:service@cnnic.cn
投诉与建议:0668-2555555
Copyright © QY Network Company Ltd. All Rights Reserved. 2003-2020 群英 版权所有
增值电信经营许可证 : B1.B2-20140078 ICP核准(ICP备案)粤ICP备09006778号 域名注册商资质 粤 D3.1-20240008