javascript - 如何在javascript数组(NodeJs)中分组(多个键)和多个属性值的总和
问题描述
什么是最有效的分组方式(多个键)和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" }
]
解决方案
你可以做到这一点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);
推荐阅读
- javascript - Phaser 3 Collider 裁剪
- swift - 与 GCD 同时处理数组项
- python - 熊猫嵌套 groupby 给出了意想不到的结果
- php - 多对多 toArray() 覆盖中的最大堆栈深度超出问题
- networking - 拥塞发生时 TCP 流的速率如何变化
- reverse-geocoding - goecoding api 免费版可以下多少订单?
- python - 错误:MySQL-python 的构建轮子失败
- python-3.x - for 循环内的东西不起作用
- selenium-webdriver - 尝试并行运行两个测试时,URL 仅针对一个测试启动
- kotlin - Ktor sse 客户端断开连接