2008-12-12 9 views
33

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

ответ

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

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

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)); 
} 
16

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

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

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

+0

Я понимаю, что этот ответ очень старый, но если кто-то задавался вопросом, зачем нужен псевдоним, свойства генерируют неявные имена полей, а методы - нет. – Jimmy 2012-11-20 23:26:39

-1

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

данныеGridView1.DataSource = New1;

+0

Этот ответ, похоже, не применяется к вопросу. – Bryan 2013-07-14 13:52:41