【发布时间】:2022-01-18 03:20:25
【问题描述】:
对数组中的对象进行分组的最有效方法是什么?
例如,给定这个对象数组:
[
{ Phase: "Phase 1", Step: "Step 1", Task: "Task 1", Value: "5" },
{ Phase: "Phase 1", Step: "Step 1", Task: "Task 2", Value: "10" },
{ Phase: "Phase 1", Step: "Step 2", Task: "Task 1", Value: "15" },
{ Phase: "Phase 1", Step: "Step 2", Task: "Task 2", Value: "20" },
{ Phase: "Phase 2", Step: "Step 1", Task: "Task 1", Value: "25" },
{ Phase: "Phase 2", Step: "Step 1", Task: "Task 2", Value: "30" },
{ Phase: "Phase 2", Step: "Step 2", Task: "Task 1", Value: "35" },
{ Phase: "Phase 2", Step: "Step 2", Task: "Task 2", Value: "40" }
]
我在表格中显示此信息。我想按不同的方法进行分组,但我想对这些值求和。
我将 Underscore.js 用于它的 groupby 函数,这很有帮助,但并不能完全解决问题,因为我不希望它们“分裂”而是“合并”,更像 SQL @987654323 @方法。
我正在寻找的内容能够汇总特定值(如果需要)。
因此,如果我使用 groupby Phase,我希望收到:
[
{ Phase: "Phase 1", Value: 50 },
{ Phase: "Phase 2", Value: 130 }
]
如果我这样做Phase/Step,我会收到:
[
{ Phase: "Phase 1", Step: "Step 1", Value: 15 },
{ Phase: "Phase 1", Step: "Step 2", Value: 35 },
{ Phase: "Phase 2", Step: "Step 1", Value: 55 },
{ Phase: "Phase 2", Step: "Step 2", Value: 75 }
]
是否有对此有用的脚本,还是我应该坚持使用 Underscore.js,然后循环遍历生成的对象以自己进行总计?
【问题讨论】:
-
虽然 _.groupBy 自己不能完成这项工作,但它可以与其他 Underscore 函数结合来完成所要求的工作。无需手动循环。看到这个答案:stackoverflow.com/a/66112210/1166087。
-
已接受答案的可读性更强的版本:
function groupBy(data, key){ return data.reduce( (acc, cur) => { acc[cur[key]] = acc[cur[key]] || []; // if the key is new, initiate its value to an array, otherwise keep its own array value acc[cur[key]].push(cur); return acc; } , []) }
标签: javascript arrays object group-by underscore.js