为了账号安全,请及时绑定邮箱和手机立即绑定

如何在javascript数组(NodeJs)中分组(多个键)和多个属性值的总和

如何在javascript数组(NodeJs)中分组(多个键)和多个属性值的总和

千万里不及你 2022-10-21 14:45:27
什么是最有效的分组方式(多个键)和javascript数组中多个属性值的总和对于前 -[     { Phase: "Phase 1", Step: "Step 1", Value1: "15", Value2: "5" },    { Phase: "Phase 1", Step: "Step 2", Value1: "20", Value2: "10" },    { Phase: "Phase 2", Step: "Step 1", Value1: "25", Value2: "15" },    { Phase: "Phase 2", Step: "Step 2", Value1: "30", Value2: "20" },    { Phase: "Phase 1", Step: "Step 1", Value1: "35", Value2: "25" },    { Phase: "Phase 1", Step: "Step 2", Value1: "40", Value2: "30" },    { Phase: "Phase 2", Step: "Step 1", Value1: "45", Value2: "35" },    { Phase: "Phase 2", Step: "Step 2", Value1: "50", Value2: "40" }]预期产出[     { Phase: "Phase 1", Step: "Step 1", Value1: "50", Value2: "30" },    { Phase: "Phase 1", Step: "Step 2", Value1: "60", Value2: "40" },    { Phase: "Phase 2", Step: "Step 1", Value1: "70", Value2: "50" },    { Phase: "Phase 2", Step: "Step 2", Value1: "80", Value2: "60" }]
查看完整描述

2 回答

?
qq_笑_17

TA贡献1818条经验 获得超7个赞

你可以做到这一点reduce并采取Object.values它:


var array = [ { Phase: "Phase 1", Step: "Step 1", Value1: "15", Value2: "5" }, { Phase: "Phase 1", Step: "Step 2", Value1: "20", Value2: "10" }, { Phase: "Phase 2", Step: "Step 1", Value1: "25", Value2: "15" }, { Phase: "Phase 2", Step: "Step 2", Value1: "30", Value2: "20" }, { Phase: "Phase 1", Step: "Step 1", Value1: "35", Value2: "25" }, { Phase: "Phase 1", Step: "Step 2", Value1: "40", Value2: "30" }, { Phase: "Phase 2", Step: "Step 1", Value1: "45", Value2: "35" }, { Phase: "Phase 2", Step: "Step 2", Value1: "50", Value2: "40" }];


var result = Object.values(array.reduce((acc, {Value1, Value2,...rest})=>{

    const key = Object.values(rest).join('|');

    acc[key] = acc[key] || {...rest, Value1:0,Value2:0};

    acc[key].Value1+=+Value1;

    acc[key].Value2+=+Value2;

    return acc;

},{}));


console.log(result);


查看完整回答
反对 回复 2022-10-21
?
BIG阳

TA贡献1859条经验 获得超6个赞

const data = [{Phase:"Phase 1",Step:"Step 1",Value1:"15",Value2:"5"},{Phase:"Phase 1",Step:"Step 2",Value1:"20",Value2:"10"},{Phase:"Phase 2",Step:"Step 1",Value1:"25",Value2:"15"},{Phase:"Phase 2",Step:"Step 2",Value1:"30",Value2:"20"},{Phase:"Phase 1",Step:"Step 1",Value1:"35",Value2:"25"},{Phase:"Phase 1",Step:"Step 2",Value1:"40",Value2:"30"},{Phase:"Phase 2",Step:"Step 1",Value1:"45",Value2:"35"},{Phase:"Phase 2",Step:"Step 2",Value1:"50",Value2:"40"}]


const finalResult = data.reduce((result, d) => {

  let key = `${d.Phase}_${d.Step}`;

  result[key] = result[key] || {...d, Value1: 0, Value2: 0};

  result[key].Value1 += +d.Value1;

  result[key].Value2 += +d.Value2


  return result

}, {})


console.log(Object.values(finalResult))


查看完整回答
反对 回复 2022-10-21
  • 2 回答
  • 0 关注
  • 161 浏览
慕课专栏
更多

添加回答

举报

0/150
提交
取消
意见反馈 帮助中心 APP下载
官方微信