温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

如何使用Node读写txt和Excel文件

发布时间:2022-10-25 09:34:20 来源:亿速云 阅读:194 作者:iii 栏目:web开发

今天小编给大家分享一下如何使用Node读写txt和Excel文件的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。

首先给出文件的内容:test.txt文件只有一句话(我是txt文件的内容);test.xlsx文件中,具体如图所示:

如何使用Node读写txt和Excel文件

如何使用Node读写txt和Excel文件

如何使用Node读写txt和Excel文件

读取txt文件

/** 引入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读写txt和Excel文件

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

/** 引入Node的文件模块 */
const fs = require("fs");

/** 测试写入 */
fs.appendFile("write.txt", "测试写入", (err, data) => {
    if (err) throw err;
});

运行如下:

如何使用Node读写txt和Excel文件

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

/** 引入Node的文件模块 */
const fs = require("fs");

const obj = {
    name: 'cc',
    age: 15
}

/** 测试写入 */
fs.writeFile("write.txt", obj, (err, data) => {
    if (err) throw err;
});

运行结果:

如何使用Node读写txt和Excel文件

这时可以通过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;
});

结果如下:

如何使用Node读写txt和Excel文件

为了使写入格式更好看一点,可以往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读写txt和Excel文件

读取Excel文件

/** 引入Node的文件模块 */
const fs = require("fs");

/** 引入Excel文件处理模块(若没安装,安装一下即可) */
const xlsx = require('node-xlsx');

/** 解析excel文档 */
const sheets = xlsx.parse('./test.xlsx');
console.log("sheets data:", sheets)

可以看到输出的结果:

如何使用Node读写txt和Excel文件

解析后的内容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读写txt和Excel文件

以上就是“如何使用Node读写txt和Excel文件”这篇文章的所有内容,感谢各位的阅读!相信大家阅读完这篇文章都有很大的收获,小编每天都会为大家更新不同的知识,如果还想学习更多的知识,请关注亿速云行业资讯频道。

向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

AI