我想用相同的键动态合并多个对象的单个数组。数据的示例是这样的:
var data = [{
ReportTime: "30 Apr 2017BDT",
Rate: "1.00000",
AvgGrowth: "0.0"
}, {
ReportTime: "30 Apr 2017BDT",
Rate: "0.01107",
AvgGrowth: "0.1"
}, {
ReportTime: "29 Apr 2017BDT",
Rate: "1.00000",
AvgGrowth: "0.0"
}, {
ReportTime: "29 Apr 2017BDT",
Rate: "0.01107",
AvgGrowth: "-0.5"
}]
我想生成这样的数据
newData = [{
"30 Apr 2017BDT",
"1.00000",
"0.0",
"0.01107",
"0.1"
}, {
"29 Apr 2017BDT",
"1.00000",
"0.0",
"0.01107",
"-0.5"
}];
我需要一个建议或帮助,以解决该问题。
答案 0 :(得分:1)
您可以使用reduce将值按ReportTime
分组
const data = [{ ReportTime: "30 Apr 2017BDT", Rate: "1.00000", AvgGrowth: "0.0"}, { ReportTime: "30 Apr 2017BDT", Rate: "0.01107", AvgGrowth: "0.1"}, { ReportTime: "29 Apr 2017BDT", Rate: "1.00000", AvgGrowth: "0.0"
}, { ReportTime: "29 Apr 2017BDT", Rate: "0.01107", AvgGrowth: "-0.5"}]
const merged = data.reduce((op, inp) => {
let key = inp.ReportTime
op[key] = op[key] || []
op[key].push(inp)
return op
}, Object.create(null))
console.log(merged)
答案 1 :(得分:1)
您的预期输出看起来不是有效的JS。但是,您可以通过使用.reduce()
,.map()
和Object.entries()
这样的几种方法遍历数组来获得数组数组:
const data = [
{ReportTime: "30 Apr 2017BDT", Rate: "1.00000", AvgGrowth: "0.0"},
{ReportTime: "30 Apr 2017BDT", Rate: "0.01107", AvgGrowth: "0.1"},
{ReportTime: "29 Apr 2017BDT", Rate: "1.00000", AvgGrowth: "0.0"},
{ReportTime: "29 Apr 2017BDT", Rate: "0.01107", AvgGrowth: "-0.5"}
];
const result = Object.entries(
data.reduce((r, {ReportTime, ...rest}) => {
r[ReportTime] = (r[ReportTime] || []).concat(Object.values(rest));
return r;
}, {})
).map(([k, v]) => [k, ...v]);
console.log(result);
.as-console-wrapper { max-height: 100% !important; top: 0; }
这是使用es5(old)语法的另一种方法:
var data = [
{ReportTime: "30 Apr 2017BDT", Rate: "1.00000", AvgGrowth: "0.0"},
{ReportTime: "30 Apr 2017BDT", Rate: "0.01107", AvgGrowth: "0.1"},
{ReportTime: "29 Apr 2017BDT", Rate: "1.00000", AvgGrowth: "0.0"},
{ReportTime: "29 Apr 2017BDT", Rate: "0.01107", AvgGrowth: "-0.5"}
];
var key = 'ReportTime';
var reducer = function(data, key) {
var result = [];
var map = {};
data.forEach(function(o, i) {
map[o[key]] = map[o[key]] || [];
for(var k in o) {
if(!(k === key)) { map[o[key]].push(o[k]); }
};
});
for(var j in map) {
result.push([].concat(j, map[j]));
};
return result;
};
console.log(reducer(data, key));
答案 2 :(得分:1)
我认为,如果将组ReportTime设置为对象并保持Rate和AvgGrowth会有所帮助。
遍历所有项目,构建一个键为“ ReportTime”的对象。 当ReportTime已存在于对象中时,只需更新Rate和AvgGrowth。 迭代后,获取上述对象的Object.values()使其作为数组。
const update = data => {
const res = {};
data.forEach(item => {
if (!res[item.ReportTime]) {
res[item.ReportTime] = {
ReportTime: item.ReportTime,
Rate: [],
AvgGrowth: []
};
}
res[item.ReportTime].Rate.push(item.Rate);
res[item.ReportTime].AvgGrowth.push(item.AvgGrowth);
});
return Object.values(res);
};
var data = [
{
ReportTime: "30 Apr 2017BDT",
Rate: "1.00000",
AvgGrowth: "0.0"
},
{
ReportTime: "30 Apr 2017BDT",
Rate: "0.01107",
AvgGrowth: "0.1"
},
{
ReportTime: "29 Apr 2017BDT",
Rate: "1.00000",
AvgGrowth: "0.0"
},
{
ReportTime: "29 Apr 2017BDT",
Rate: "0.01107",
AvgGrowth: "-0.5"
}
];
console.log(update(data));