gpt4 book ai didi

angular - 使用 primeNG 和 dataTable 进行 CSV 导出的嵌套 json 对象

转载 作者:行者123 更新时间:2023-12-02 16:54:47 25 4
gpt4 key购买 nike

我们有一个嵌套 JSON 对象,用于对象导出 CSV 的 json 平面级别,该对象正在工作,但对于嵌套对象,它不起作用(站点对象)

对于此实现,我们使用了 PrimeNg 库:

下面是 json 响应:

 "data": [
{
"towerId": "gfsjfdy32ur",
"towerName": "qjdhkud",
"exAxisTower": false,
"tbuShareable": null,
"technologyPartnerRNP": "TP_RNP_EID",
"technologyPartnerTNP": "TP_TNP_EID",
"ssrLongitude": "323",
"ssrLatitude": "323",
"region": "REG_J",
"province": "PROV_SU",
"district": "PROV_SU_D1",
"scheme": null,
"towerType": "TYPE_CL",
"towerKind": null,
"category": "CAT_SM",
"proposedHeight": 323,
"useShelter": "SHELT_Y",
"azimuth": "dewdew",
"towerProviderNumber": null,
"towerProviderName": null,
"farEnd1": null,
"farEnd2": null,
"farEnd3": null,
"towerStatus": "Plan on Progress",
"projectStatus": "SSR Completed",
"sites": [
{
"id": "6a056c60-5774-40ad-bd00-2523cbfdb8a4",
"created": "2019-12-09T10:52:18.293+0000",
"createdId": "ff06c5a4-135c-40b7-83f3-3648ec035efc",
"modified": "2019-12-09T10:52:18.293+0000",
"modifiedId": "ff06c5a4-135c-40b7-83f3-3648ec035efc",
"siteId": "siteid value 1",
"siteName": "site name value 1",
"ssrId": "d6c4fa53-a8f3-4b53-b592-a0c1646c1d46"
},
{
"id": "6a056c60-5774-40ad-535434",
"created": "2019-12-09T10:52:18.293+0000",
"createdId": "ff06c5a4-135c-40b7-83f3-3648ec035efc",
"modified": "2019-12-09T10:52:18.293+0000",
"modifiedId": "ff06c5a4-135c-40b7-83f3-3648ec035efc",
"siteId": "site Id value 1",
"siteName": " site Name value2",
"ssrId": "d6c4fa53-a8f3-4b53-b592-a0c1646c1d46"
}
],
"projectName": "fje",
"commitmentNumber": null,
"rfiSLA": null,
"trialPeriod": null,
"cmeType": null,
"ownerShip": null,
"banDocument": null,
"slaDocument": null
},
{
"towerId": "327",
"towerName": "dws",
"exAxisTower": false,
"tbuShareable": null,
"technologyPartnerRNP": "TP_RNP_EID",
"technologyPartnerTNP": "TP_TNP_EID",
"ssrLongitude": "324234",
"ssrLatitude": "34324",
"region": "REG_J",
"province": "PROV_AC",
"district": "PROV_AC_D2",
"scheme": null,
"towerType": "TYPE_CL",
"towerKind": null,
"category": "CAT_MA",
"proposedHeight": 434,
"useShelter": "SHELT_Y",
"azimuth": "2342432",
"towerProviderNumber": null,
"towerProviderName": null,
"farEnd1": null,
"farEnd2": null,
"farEnd3": null,
"towerStatus": "Plan on Progress",
"projectStatus": "SSR Completed",
"sites": [
{
"id": "00db69ed-dfd0-439a-a879-bc8dfaf5a9bf",
"created": "2019-12-09T10:54:06.686+0000",
"createdId": "ff06c5a4-135c-40b7-83f3-3648ec035efc",
"modified": "2019-12-09T10:54:06.686+0000",
"modifiedId": "ff06c5a4-135c-40b7-83f3-3648ec035efc",
"siteId": "",
"siteName": "",
"ssrId": "761e6545-9179-4fbb-8c80-eaa0c8095ad7"
}
],
"projectName": "ewe",
"commitmentNumber": null,
"rfiSLA": null,
"trialPeriod": null,
"cmeType": null,
"ownerShip": null,
"banDocument": null,
"slaDocument": null
}
]

CSV 应该导出如下格式:

enter image description here

假设站点对象中有第n个对象,那么在导出csv时需要添加这些许多站点ID和站点名称

我们正在使用 primeNg 表。

最佳答案

prime-ng table 不支持按您想要的方式导出 csv。因此,必须要写。

我写了导出csv的方法。我希望这有帮助。

Stackblitz Sample

data: Data[];
csvSeparator = ";";
exportFilename = "exportData";
columns = [
{ field: "towerId", header: "towerId", exportable: true },
{ field: "towerName", header: "towerName", exportable: false },
{ field: "province", header: "province", exportable: true },
{ field: "district", header: "district", exportable: true },
{
field: "sites.siteId",
header: "sitesid",
exportable: true,
details: true
},
{
field: "sites.siteName",
header: "siteName",
exportable: true,
details: true
}
];

exportCSV() {
let csv = '';
const csvHeaders = new Map();

this.data.forEach((record, i) => {
for (let i = 0; i < this.columns.length; i++) {
const column = this.columns[i];
if (column.exportable !== false && column.field) {
if (column.details) {
const fields = column.field.split('.');
const detailField = fields[fields.length - 1];
record[fields[0]].forEach((detailRecord, j) => {
const csvHeader = '"' + (column.header || column.field) + j + '"';
const detailFieldId = detailField + j;
if (!csvHeaders.has(detailFieldId)) {
csvHeaders.set(detailFieldId, csvHeader);
}
let detailCellData = detailRecord[detailField];
if (detailCellData != null) {
detailCellData = String(detailCellData).replace(/"/g, '""');
} else {
detailCellData = '';
}
csv += '"' + detailCellData + '"';

if (i < (this.columns.length - 1)) {
csv += this.csvSeparator;
}
});
} else {
const csvHeader = '"' + (column.header || column.field) + '"';
if (!csvHeaders.has(column.field)) {
csvHeaders.set(column.field, csvHeader);
}
let cellData = record[column.field];
if (cellData != null) {
cellData = String(cellData).replace(/"/g, '""');
} else {
cellData = '';
}
csv += '"' + cellData + '"';

if (i < (this.columns.length - 1)) {
csv += this.csvSeparator;
}
}
}
}
csv += '\n';
});
csv = Array.from(csvHeaders.values()).join(this.csvSeparator) + '\n' + csv;
const blob = new Blob([csv], {
type: 'text/csv;charset=utf-8;'
});

if (window.navigator.msSaveOrOpenBlob) {
navigator.msSaveOrOpenBlob(blob, this.exportFilename + '.csv');
} else {
const link = document.createElement('a');
link.style.display = 'none';
document.body.appendChild(link);
if (link.download !== undefined) {
link.setAttribute('href', URL.createObjectURL(blob));
link.setAttribute('download', this.exportFilename + '.csv');
link.click();
} else {
csv = 'data:text/csv;charset=utf-8,' + csv;
window.open(encodeURI(csv));
}
document.body.removeChild(link);
}
}

关于angular - 使用 primeNG 和 dataTable 进行 CSV 导出的嵌套 json 对象,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/59262940/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com