npm linq: Группировка нескольких столбцов - PullRequest
1 голос
/ 06 мая 2020

Я пытаюсь сгруппировать по 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 () при выборе данных. Мой вопрос: правильно ли это сделать? Или мне что-то не хватает?

1 Ответ

1 голос
/ 06 мая 2020

У меня нет опыта работы с linq. js, но я дам некоторые идеи, основанные на моем C# опыте и на том, что я могу почерпнуть из документации.

Это выглядит так есть дополнительные аргументы, которые вы можете предоставить функции 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();
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...