导出表格数据

npm i "xlsx": "^0.18.5"

import { read, utils, writeFile } from "xlsx";

export function exportExcel(json, name, titleArr, sheetName) {

    var data = new Array();

    var keyArray = new Array();

    const getLength = function (obj) {

        var count = 0;

        for (var i in obj) {

            if (obj.hasOwnProperty(i)) {

                count++;

            }

        }

        return count;

    };

    for (const key1 in json) {

        if (json.hasOwnProperty(key1)) {

            const element = json[key1];

            var rowDataArray = new Array();

            for (const key2 in element) {

                if (element.hasOwnProperty(key2)) {

                    const element2 = element[key2];

                    rowDataArray.push(element2);

                    if (keyArray.length < getLength(element)) {

                        keyArray.push(key2);

                    }

                }

            }

            data.push(rowDataArray);

        }

    }

    data.splice(0, 0, keyArray, titleArr);

    console.log("data", data);

    const ws = utils.aoa_to_sheet(data);

    const wb = utils.book_new();

    var wsrows = [{ hidden: true }];

    ws["!rows"] = wsrows;

    utils.book_append_sheet(wb, ws, sheetName);

    writeFile(wb, name + ".xlsx");

}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值