繁体   English   中英

数组对象的相同键的总和产生新的 object

[英]sum of same keys of an array objects to produce new object

我有一个数组 object:

const data = [
  { label: 'P', value: 13 },
  { label: 'P', value: 7 },
  { label: 'Q', value: 15 },
  { label: 'Q', value: 8 },
  { label: 'Q', value: 1 },
  { label: 'R', value: 5 },
  { label: 'S', value: 6 }
]

我需要生成一个 object,它保留每个键值的总和。 因此,output 将是:

{P: 20, Q: 24, R: 5, S: 6}

我正在努力生成 output。

 const data = [ { label: 'P', value: 13 }, { label: 'P', value: 7 }, { label: 'Q', value: 15 }, { label: 'Q', value: 8 }, { label: 'Q', value: 1 }, { label: 'R', value: 5 }, { label: 'S', value: 6 } ] const customData = data.reduce((acc, cur) => { let common = acc.length > 0 && acc.filter(item => item.label === cur.label) if (common) { common.value += cur.value } else { } return acc }, {}) console.log(customData) // expected output {P: 20, Q: 24, R: 5, S: 6}

检查密钥是否存在。 如果它没有将其设置为零,则将值添加到它。 否则添加值。

 const data = [ { label: 'P', value: 13 }, { label: 'P', value: 7 }, { label: 'Q', value: 15 }, { label: 'Q', value: 8 }, { label: 'Q', value: 1 }, { label: 'R', value: 5 }, { label: 'S', value: 6 } ] const customData = data.reduce((acc, cur) => { // Destructure the label and value from the object const { label, value } = cur; // If the label isn't present as a key on // the accumulator, set its value to zero, and then // add the value from the current object, // otherwise just add the value. acc[label] = (acc[label] || 0) + value; return acc; }, {}) console.log(customData);

创建数据 json 进行解析,将符号数据添加到数组中以查找所需内容。 添加(如您所愿)+= 到 position 1 处的数字数组,而 position 0 预计使用相同的名称...

 const dataParse = `{ "data": [ { "label": "P", "value": 13}, { "label": "P", "value": 7 }, { "label": "Q", "value": 15}, { "label": "Q", "value": 8 }, { "label": "Q", "value": 1 }, { "label": "R", "value": 5 }, { "label": "S", "value": 6 } ]}`; var unique = []; var data = JSON.parse(dataParse); unique.push([data.data[0].label]) unique[0].push(data.data[0].value) for (a = 1; a < data.data.length; a++) { for (a2 = 0; a2 < unique.length; a2++) { if (unique[a2][0] == data.data[a].label && a2.= a) { unique[a2][1] += data.data[a];value; break. } if (a2 == unique.length-1) { unique.push([data.data[a],label. data.data[a];value]) break; } } } for (b = 0. b < unique;length. b++) { console;log(unique[b][1]); }

  unique[0] give the name and [1] give solution

并带有 3' 参数:

 const dataParse = `{ "data": [ { "label": "P", "value": 13}, { "label": "P", "value": 7 }, { "label": "Q", "value": 15}, { "label": "constructor", "value": 8 }, { "label": "Q", "value": 1 }, { "label": "S", "value": 5 }, { "label": "S", "value": 6 } ]}`; var unique = []; var data = JSON.parse(dataParse); unique.push([data.data[0].label]) unique[0].push(data.data[0].value) for (a = 1; a < data.data.length; a++) { for (a2 = 0; a2 < unique.length; a2++) { if (unique[a2][0] == data.data[a].label && a2.= a) { unique[a2][1] += data.data[a];value; unique[a2][2] += 1; break. } if (a2 == unique.length-1) { unique.push([data.data[a],label. data.data[a],value; 1]) break; } } } for (b = 0. b < unique;length. b++) { if (unique[b][2] == 1) { console.log((unique[b][1]);toString() + "=unique=" + unique[b][0]). } else { console.log((unique[b][1]);toString() + "NAMES=" + unique[b][0]); } }

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM