从JS中的JSON对象检索数据

问题描述 投票:0回答:5

我在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"]}]

我相信我必须搜索数据帧,但我认为我的主要问题是我用来进行富有成效的研究的不良词汇。

非常感谢 !

javascript arrays json dataframe
5个回答
3
投票

这是一个转换数据结构的基本脚本:

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

1
投票

你可以使用reduceObject.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);

0
投票

以下是您需要的基本转换:

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

0
投票

我认为最好使用这样的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)

现在代码紧凑,更易读


-1
投票

所以你想使用group by。您想按键对mystuff对象进行分组。

© www.soinside.com 2019 - 2024. All rights reserved.