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");
}