web-dev-qa-db-fra.com

Liste C # <> Valeurs GroupBy 2

J'utilise C # sur Framework 3.5. Je cherche à regrouper rapidement une liste générique <> par deux propriétés. Pour les besoins de cet exemple, disons que j'ai une liste d'un type de commande avec les propriétés CustomerId, ProductId et ProductCount. Comment puis-je obtenir la somme des ProductCounts groupés par CustomerId et ProductId en utilisant une expression lambda?

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

Alternativement, si vous souhaitez obtenir les identifiants pour chaque somme, vous pouvez le faire

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
Klas Mellbourn