GroupBy
GroupBy 是一种将 IEnumerable<T>
项目集合分类到不同组的简单方法。
简单的例子
在第一个例子中,我们最终得到两个组,奇数项和偶数项。
List<int> iList = new List<int>() { 1, 2, 3, 4, 5, 6, 7, 8, 9 };
var grouped = iList.GroupBy(x => x % 2 == 0);
//Groups iList into odd [13579] and even[2468] items
foreach(var group in grouped)
{
foreach (int item in group)
{
Console.Write(item); // 135792468 (first odd then even)
}
}
更复杂的例子
让我们按年龄分组人员列表作为例子。首先,我们将创建一个 Person 对象,它具有 Name 和 Age 两个属性。
public class Person
{
public int Age {get; set;}
public string Name {get; set;}
}
然后我们创建具有不同名称和年龄的人员样本列表。
List<Person> people = new List<Person>();
people.Add(new Person{Age = 20, Name = "Mouse"});
people.Add(new Person{Age = 30, Name = "Neo"});
people.Add(new Person{Age = 40, Name = "Morpheus"});
people.Add(new Person{Age = 30, Name = "Trinity"});
people.Add(new Person{Age = 40, Name = "Dozer"});
people.Add(new Person{Age = 40, Name = "Smith"});
然后我们创建一个 LINQ 查询,按年龄对我们的人员列表进行分组。
var query = people.GroupBy(x => x.Age);
这样,我们可以看到每个组的年龄,并列出该组中的每个人。
foreach(var result in query)
{
Console.WriteLine(result.Key);
foreach(var person in result)
Console.WriteLine(person.Name);
}
这导致以下输出:
20
Mouse
30
Neo
Trinity
40
Morpheus
Dozer
Smith
你可以在 .NET Fiddle 上使用现场演示