簡體   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