在LINQ中,可以使用GroupBy
方法将集合基于属性存储到一组列表中。以下是一个C#示例,假设有一个Person
类,其中包含Age
属性:
using System;
using System.Collections.Generic;
using System.Linq;
class Person
{
public string Name { get; set; }
public int Age { get; set; }
}
class Program
{
static void Main(string[] args)
{
List<Person> people = new List<Person>
{
new Person { Name = "Alice", Age = 25 },
new Person { Name = "Bob", Age = 30 },
new Person { Name = "Charlie", Age = 25 },
new Person { Name = "David", Age = 30 },
new Person { Name = "Eve", Age = 20 }
};
var groupedPeople = people.GroupBy(p => p.Age);
foreach (var group in groupedPeople)
{
Console.WriteLine($"Age: {group.Key}");
Console.WriteLine(string.Join(", ", group.Select(p => p.Name)));
}
}
}
输出结果:
Age: 20
Eve
Age: 25
Alice, Charlie
Age: 30
Bob, David
在这个示例中,我们使用GroupBy
方法将people
列表中的Person
对象按照Age
属性分组,然后遍历每个分组并输出分组中的Person
对象的Name
属性。
这种方法非常优雅,因为它使用LINQ提供的内置功能来实现分组,而不需要手动编写循环和条件语句。此外,这种方法可以轻松地扩展到更复杂的分组和排序需求。
领取专属 10元无门槛券
手把手带您无忧上云