C# LINQ GroupBy操作详解与示例

4 下载量 154 浏览量 更新于2024-08-31 收藏 170KB PDF 举报
"这篇资源主要介绍了如何在C#中使用LINQ的GroupBy方法来对数据进行分组操作。通过创建一个Person类和一个Person对象列表,演示了如何基于类的特定属性(如Gender)对数据进行分组,并展示了相关的C#代码示例。" 在C#中,LINQ(Language Integrated Query,语言集成查询)提供了一种强大而简洁的方式来处理数据。GroupBy方法是LINQ中非常重要的一个功能,它允许我们根据数据源中元素的某个或多个属性将数据分组成不同的组。在这个例子中,我们将看到如何在实际的代码场景中使用GroupBy。 首先,定义了一个名为Person的类,包含了三个属性:Name、Age和Gender。这个类用于模拟具有这些属性的实体,例如人。然后,我们创建了一个Person类型的List实例`personList`,其中包含若干个Person对象,每个对象都有独特的Name、Age和Gender。 接下来,我们展示了GroupBy方法的第一个基本用法。`GroupBy`方法接收一个参数,即一个Func委托,这个委托用于从数据源中的每个元素提取分组键。在本例中,我们将`p => p.Gender`作为keySelector,这意味着我们将根据Person对象的Gender属性来对数据进行分组。 调用`personList.GroupBy(p => p.Gender)`后,返回的是一个`IEnumerable<IGrouping<TKey, TSource>>`,其中每个组都是一个实现了`IGrouping<TKey, TSource>`接口的对象。`IGrouping<TKey, TSource>`接口代表了一个键值关联的元素集合,这里的键是分组依据(Gender),元素是属于该组的Person对象。 为了展示分组的结果,我们使用了两个嵌套的`foreach`循环。外层循环遍历所有的组(groups),打印出每个组的键(Gender)。内层循环则遍历每个组内的Person对象,打印出他们的Name和Age。这样,我们就可以清晰地看到按照Gender分组后的人员列表。 通过这种方式,我们可以方便地对数据进行聚合和分类,比如在报表生成、数据分析或任何需要根据特定属性组织数据的场景中。在更复杂的场景中,GroupBy还可以接受多个keySelector,对数据进行多级分组,或者配合其他LINQ方法如Select和Where,实现更复杂的查询逻辑。