我在JS中遇到了一个JSON对象。我想为数据集合中的所有对象检索每个字符串的值数组。
例如,我有
mystuff = [{"item1":"12", "item2":"25", "item3":"16"},
{"item1":"14", "item2":"21", "item3":"18"},
{"item1":"13", "item2":"22", "item3":"17"}]
而我正在寻找
theGoodOne = [{"item1":["12", "14","13"]},
{"item2":["25","21","22"]},
{"item3":["16","18","17"]}]
我相信我必须搜索数据帧,但我认为我的主要问题是我用来进行富有成效的研究的不良词汇。
非常感谢 !
这是一个转换数据结构的基本脚本:
mystuff =
[{"item1":"12", "item2":"25", "item3":"16"},
{"item1":"14", "item2":"21", "item3":"18"},
{"item1":"13", "item2":"22", "item3":"17"}];
var theGoodOne = mystuff.reduce(function(acc, el){
Object.keys(el).forEach(function(k){
if (el.hasOwnProperty(k)) {
acc[k] = acc[k] || [];
acc[k].push(el[k]);
}
});
return acc;
}, {});
console.log(theGoodOne);
你可以使用reduce
和Object.values
来实现它。
let mystuff = [{"item1":"12", "item2":"25", "item3":"16"},
{"item1":"14", "item2":"21", "item3":"18"},
{"item1":"13", "item2":"22", "item3":"17"}];
let theGoodOne = Object.values(mystuff.reduce((c, v) => {
for (var k in v) {
c[k] = c[k] ? c[k] : {};
c[k][k] = c[k][k] || [];
c[k][k].push(v[k]);
}
return c;
}, {}));
console.log(theGoodOne);
以下是您需要的基本转换:
const mystuff = [{"item1":"12", "item2":"25", "item3":"16"},{"item1":"14", "item2":"21", "item3":"18"},
{"item1":"13", "item2":"22", "item3":"17"}];
let response = [];
let keys = []
for(const mystuffKeys of mystuff){
for(const k of Object.keys(mystuffKeys)) {
if(!keys.includes(k)) {
keys.push(k);
}
}
}
for(const key of keys) {
const valArr = mystuff.map((item) => item[key])
let data = {};
data[key] = valArr;
response.push(data);
}
console.log(response);
我认为最好使用这样的es6表示法:
let Good = {}
mystuff.forEach(stuff=>{
for (const key in stuff){
Good[key] = Good[key] ? Good[key] : []
Good[key]=[ ...Good[key], stuff[key]]
}
})
console.log(Good)
现在代码紧凑,更易读
所以你想使用group by。您想按键对mystuff
对象进行分组。