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

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

12.12.2008 18:10:25
4 ОТВЕТА
РЕШЕНИЕ
var sums = Orders.GroupBy(x => new { x.CustomerID, x.ProductID })
                 .Select(group => group.Sum(x => x.ProductCount));
57
8.03.2013 22:37:22

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

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));
}
7
14.12.2008 23:40:20

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

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

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

16
19.05.2010 19:59:52
Я понимаю, что этот ответ очень старый, но если кому-то интересно, зачем нужен псевдоним, свойства генерируют неявные имена полей, а методы - нет.
Jimmy 20.11.2012 23:26:39

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

dataGridView1.DataSource = New1;

-1
1.04.2013 14:17:52
Этот ответ не относится к вопросу.
Bryan 14.07.2013 13:52:41