gpt4 book ai didi

javascript - 如何转换我的对象数组以获得此输出?

转载 作者:行者123 更新时间:2023-12-01 01:49:05 24 4
gpt4 key购买 nike

我有一个对象数组,需要更改它才能在我的 Angular 应用程序中插入图表。以下是我的尝试。我需要帮助来弄清楚如何更改当前的代码以获得所需的输出。我仍在学习 javascript,并认为自己是一名学生。因此,任何解释或指导都将受到欢迎。

所需的输出与此类似。这是我的引用。

[
{
"name": "Seychelles",
"series": [
{
"value": 5452,
"name": "2016-09-19T10:32:55.756Z"
},
{
"value": 3412,
"name": "2016-09-17T10:51:42.303Z"
},
{
"value": 3270,
"name": "2016-09-12T22:19:48.181Z"
},
{
"value": 2061,
"name": "2016-09-22T14:10:00.900Z"
},
{
"value": 2717,
"name": "2016-09-21T01:34:27.855Z"
}
]
},
{
"name": "Andorra",
"series": [
{
"value": 4200,
"name": "2016-09-19T10:32:55.756Z"
},
{
"value": 5142,
"name": "2016-09-17T10:51:42.303Z"
},
{
"value": 5999,
"name": "2016-09-12T22:19:48.181Z"
},
{
"value": 3736,
"name": "2016-09-22T14:10:00.900Z"
},
{
"value": 5471,
"name": "2016-09-21T01:34:27.855Z"
}
]
},
{
"name": "Barbados",
"series": [
{
"value": 2332,
"name": "2016-09-19T10:32:55.756Z"
},
{
"value": 2341,
"name": "2016-09-17T10:51:42.303Z"
},
{
"value": 2488,
"name": "2016-09-12T22:19:48.181Z"
},
{
"value": 5246,
"name": "2016-09-22T14:10:00.900Z"
},
{
"value": 5871,
"name": "2016-09-21T01:34:27.855Z"
}
]
},
{
"name": "Peru",
"series": [
{
"value": 3122,
"name": "2016-09-19T10:32:55.756Z"
},
{
"value": 3925,
"name": "2016-09-17T10:51:42.303Z"
},
{
"value": 3268,
"name": "2016-09-12T22:19:48.181Z"
},
{
"value": 4939,
"name": "2016-09-22T14:10:00.900Z"
},
{
"value": 4336,
"name": "2016-09-21T01:34:27.855Z"
}
]
},
{
"name": "Romania",
"series": [
{
"value": 2169,
"name": "2016-09-19T10:32:55.756Z"
},
{
"value": 3850,
"name": "2016-09-17T10:51:42.303Z"
},
{
"value": 6793,
"name": "2016-09-12T22:19:48.181Z"
},
{
"value": 4827,
"name": "2016-09-22T14:10:00.900Z"
},
{
"value": 2696,
"name": "2016-09-21T01:34:27.855Z"
}
]
}
]

这是我的尝试,也是要转换的原始数据的示例。

function cleanData(data) {
const emp = [];
const keys = Object.keys(data[0]);

for (let i = 0; i < data.length; i++) {
if(keys[i] != 'date') {
let obj = {};
let obj2 = {};
obj["name"] = keys[i];
obj["series"] = [];
obj2["values"] = data[i][keys[i]]
obj2["name"] = data[i].date
obj["series"].push(obj2);
emp.push(obj);
}
}
console.log(emp);
}

const arr = [
{
"date": "2018-07-01",
"nb_uniq_visitors": 573,
"nb_visits": 621,
"nb_users": 50,
"nb_actions": 1102,
"max_actions": 23,
"bounce_count": 381
},
{
"date":"2018-07-02",
"nb_uniq_visitors": 243,
"nb_visits": 571,
"nb_users": 67,
"nb_actions": 1002,
"max_actions": 33,
"bounce_count": 452
},
{
"date": "2018-07-03",
"nb_uniq_visitors": 203,
"nb_visits": 98,
"nb_users": 66,
"nb_actions": 902,
"max_actions": 73,
"bounce_count": 432
}
];
cleanData(arr);

最佳答案

尝试reduce为按名称(对象的键)索引的对象,然后对结果调用Object.values将其转回数组:

const arr=[{"date":"2018-07-01","nb_uniq_visitors":573,"nb_visits":621,"nb_users":50,"nb_actions":1102,"max_actions":23,"bounce_count":381},{"date":"2018-07-02","nb_uniq_visitors":243,"nb_visits":571,"nb_users":67,"nb_actions":1002,"max_actions":33,"bounce_count":452},{"date":"2018-07-03","nb_uniq_visitors":203,"nb_visits":98,"nb_users":66,"nb_actions":902,"max_actions":73,"bounce_count":432}];

const itemsByKey = arr.reduce((a, { date, ...obj }) => {
Object.entries(obj).forEach(([key, value]) => {
if (!a[key]) a[key] = { name: key, series: [] };
a[key].series.push({ name: date, value });
});
return a;
}, {});
console.log(Object.values(itemsByKey));

关于javascript - 如何转换我的对象数组以获得此输出?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/51718687/

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