加入收藏 | 设为首页 | 会员中心 | 我要投稿 银川站长网 (https://www.0951zz.com/)- 云通信、基础存储、云上网络、机器学习、视觉智能!
当前位置: 首页 > 综合聚焦 > 编程要点 > 语言 > 正文

Node读写txt和Excel格式文件咋办

发布时间:2023-06-27 13:43:41 所属栏目:语言 来源:
导读:今天小编跟大家讲解下有关“Node读写txt和Excel格式文件怎样做?”的内容 ,相信小伙伴们对这个话题应该有所关注吧,小编也收集到了相关资料,希望小伙伴们看了有所帮助。前端有时要处理一些数据(比如多语

今天小编跟大家讲解下有关“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文件的内容

登录后复制

写入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文件如果不存在的话也会自动创建。

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

(编辑:银川站长网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!