在C#中,我们可以使用LINQ(Language Integrated Query)查询来实现对集合的分组(group)操作以及聚合函数(如Sum、Average、Min、Max等)的结合使用
首先,假设我们有一个Person
类,如下所示:
public class Person { public int Id { get; set; } public string Name { get; set; } public int Age { get; set; } }
接下来,我们创建一个List
来存储一些示例数据:
var people = new List{ new Person { Id = 1, Name = "Alice", Age = 30 }, new Person { Id = 2, Name = "Bob", Age = 25 }, new Person { Id = 3, Name = "Charlie", Age = 35 }, new Person { Id = 4, Name = "David", Age = 28 }, new Person { Id = 5, Name = "Eva", Age = 32 }, };
现在,我们想要根据年龄对这些人进行分组,并计算每个年龄组的总年龄。我们可以使用LINQ查询和聚合函数结合GroupBy
方法来实现这个需求:
var ageGroupResult = people .GroupBy(p => p.Age) .Select(g => new { AgeGroup = g.Key, TotalAge = g.Sum(p => p.Age) }) .ToList();
在这个查询中,我们首先使用GroupBy
方法根据年龄对people
列表进行分组。然后,我们使用Select
方法来选择每个年龄组及其总年龄(使用Sum
聚合函数计算)。最后,我们将结果转换为一个新的匿名类型列表并输出。
运行这段代码,你将得到以下输出:
AgeGroup = 25, TotalAge = 28 AgeGroup = 28, TotalAge = 28 AgeGroup = 30, TotalAge = 30 AgeGroup = 32, TotalAge = 32 AgeGroup = 35, TotalAge = 35
这样,我们就实现了C#中分组操作与聚合函数的结合使用。