【问题标题】:npm linq: Grouping Multiple columnsnpm linq:分组多列
【发布时间】:2020-08-21 22:53:09
【问题描述】:

我正在尝试按对象数组中的 2 列分组,并获得一个值的分组总和。我一直在使用 linq,这是代码:

import Enumerate from "linq";

let data = [ 
{ 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" }
];

var result = Enumerate.from(data)
.groupBy((x) => x.Phase + ':'+ x.Task)
.select((x) => {
  return {
    Phase: x.first().Phase,
    Task: x.first().Task,
    Value: x.sum((y)=> y.Value | 0)
  };
})
.toArray();

console.log (result);

我得到了预期的结果:

Array(4)[
0: Object { Phase: "Phase 1" ,Task: "Task 1" ,Value: 20 }
1: Object { Phase: "Phase 1" ,Task: "Task 2" ,Value: 30 }
2: Object { Phase: "Phase 2" ,Task: "Task 1" ,Value: 60 }
3: Object { Phase: "Phase 2" ,Task: "Task 2" ,Value: 70 }
length: 4
]

我有点挣扎才能得出这个结果,并且在选择数据时不得不使用一些变通方法,例如 groupBy 和 x.first() 中的字符串键。我的问题是,这是正确的方法吗?还是我错过了什么?

【问题讨论】:

    标签: javascript grouping linq.js


    【解决方案1】:

    我没有使用 linq.js 的经验,但我会根据我的 C# 经验以及我从文档中收集到的内容提供一些见解。

    looks like 您可以为groupBy 函数提供额外的参数以使其更优雅。论据是:

    1. 键选择器
    2. 值选择器
    3. 一个选择器,将键和值合并到每组所需的输出中
    4. 比较选择器,用于从 #1 中生成的键生成可比较的值

    所以我认为这样的事情应该可行:

    var result = Enumerate.from(data)
    .groupBy((x) => ({Phase: x.Phase, Task: x.Task}),
             (x) => x.Value | 0,
             (key, values) => ({
                 Phase: key.Phase,
                 Task: key.Task,
                 Value: values.sum()
             }),
             (key) => key.Phase + ':'+ key.Task)
    )
    .toArray();
    

    【讨论】:

    • 非常好,谢谢,只需要在选择器中添加一个额外的括号。 x => ({ Phase: x.Phase, Task: x.Task }),
    猜你喜欢
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2015-12-06
    • 2013-11-27
    • 1970-01-01
    • 2014-07-08
    • 2017-04-06
    相关资源
    最近更新 更多