• 技术文章 >web前端 >js教程

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

    青灯夜游青灯夜游2022-10-24 20:25:03转载221

    大前端零基础入门到就业:进入学习

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

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

    txt内容sheet1excel内容

    读取txt文件

    废话不多说,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字符串化

    为了使写入格式更好看一点,可以往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;
    });

    插入tab缩进

    读取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文件如果不存在的话也会自动创建。运行结果如下:

    写入Excel

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

    更多node相关知识,请访问:nodejs 教程

    以上就是带你使用Node读写txt和Excel文件的详细内容,更多请关注php中文网其它相关文章!

    声明:本文转载于:csdn,如有侵犯,请联系admin@php.cn删除

    前端(VUE)零基础到就业课程:点击学习

    清晰的学习路线+老师随时辅导答疑

    快捷开发Web应用及小程序:点击使用

    支持亿级表,高并发,自动生成可视化后台。

    专题推荐:nodejs node Node.js
    上一篇:一文聊聊JavaScript中的NaN 下一篇:自己动手写 PHP MVC 框架(40节精讲/巨细/新人进阶必看)

    相关文章推荐

    • ❤️‍🔥共22门课程,总价3725元,会员免费学• ❤️‍🔥接口自动化测试不想写代码?• 浅析Nodejs怎么进行大文件读写• 浅谈node.js的后端路由自动加载• 一文探究Node中的的进程与子进程• 如何利用Node获取物理网卡mac地址• 聊聊使用Node如何实现轻量化进程池和线程池
    1/1

    PHP中文网