Список С# <> Значения GroupBy 2

Я использую С# в Framework 3.5. Я хочу быстро сгруппировать общий список < > двумя свойствами. Ради этого примера можно сказать, что у меня есть список типов Order с свойствами CustomerId, ProductId и ProductCount. Как получить сумму ProductCounts, сгруппированных по CustomerId и ProductId, с помощью выражения лямбда?

Ответ 1

var sums = Orders.GroupBy(x => new { x.CustomerID, x.ProductID })
                 .Select(group => group.Sum(x => x.ProductCount));

Ответ 2

Я понимаю, что эта ветка очень старая, но поскольку я просто боролся с этим синтаксисом, я думал, что опубликую свои дополнительные выводы - вы можете вернуть сумму и идентификаторы (без использования foreach) в одном запросе:

var sums = Orders
            .GroupBy(x => new { x.CustomerID, x.ProductID })
            .Select(group =>new {group.Key, ProductCount = group.Sum(x => x.ProductCount)});

Трудная часть для меня, чтобы заставить ее работать, состоит в том, что сумма должна быть сглажена, по-видимому...

Ответ 3

В качестве альтернативы, если вы хотите получить идентификаторы для каждой суммы, вы можете сделать это

var customerAndProductGroups =
    from order in Orders
    orderby order.CustomerID, order.ProductID // orderby not necessary, but neater
    group order by new { order.CustomerID, order.ProductID };

foreach (var customerAndProductGroup in customerAndProductGroups)
{
    Console.WriteLine("Customer {0} has ordered product {1} for a total count of {2}",
        customerAndProductGroup.Key.CustomerID,
        customerAndProductGroup.Key.ProductID,
        customerAndProductGroup.Sum(item => item.ProductCount));
}

Ответ 4

var New1 = EmpList.GroupBy(z = > z.Age).OrderBy(Employee = > Employee.Key);

dataGridView1.DataSource = New1;