node后端使用node-xlsx生成excel文档

后端生成excel

场景:每日订单数据导出为excel。

使用npm库 node-xlsx
//引入node-xlsx包,以及生成文件相关的fs,path包
const xlsx = require("node-xlsx");
const fs = require("fs");
const path = require("path");

//定义excel数据
let excelDataMap = [];
//设置excel第一行的数据(表头)
excelDataMap[0] = [
  "订单号",
  "xxx",
  "xxx",
  "xxx",
  "xxx",
   ...
];

let index = 0;
//拼接Excel的其他数据,一个订单一行
for (const order of orders) {
  index++;
  excelDataMap.push([
    order.code,
    xxxx,
    xxxx,
    xxxx,
    xxxx,
    ...
  ]);
}

//设置Excel的行宽
const sheetOptions = {
  "!cols": [
    { wch: 20 },
    { wch: 20 },
    { wch: 20 },
    { wch: 20 },
    { wch: 20 },
    ...
  ],
};

//使用xlsx库创建excel原数据buffer
const buffer = xlsx.build([{ name: "订单", data: excelDataMap }], {
 sheetOptions,
});
	
//生成文件
let time = new Date().getTime();
await new Promise((resolve, reject) => {
  fs.writeFile(
    path.join(
      __dirname,
      `./static/order-${time}.xlsx`
    ),
    buffer,
    (err, buffer) => {
      if (err) {
        console.log(err);
        reject(err);
      } else {
        resolve(buffer);
      }
    }
  );
});

node-xlsx的详细参数,可自行查阅官方git文档

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值