C# list根据多个列分组

时间: 2023-07-12 18:42:20 浏览: 49
在C#中对List进行多列分组可以使用匿名类型作为分组键。以下是一个示例: 假设我们有一个包含Person对象的List,每个Person对象都有一个Age属性和一个City属性。我们想要按照年龄和城市将Person对象进行分组。可以使用以下代码: ```csharp List<Person> people = new List<Person>(); // 添加Person对象到List中 var groupedPeople = people.GroupBy(p => new { p.Age, p.City }); foreach (var group in groupedPeople) { Console.WriteLine("Age: " + group.Key.Age + ", City: " + group.Key.City); foreach (var person in group) { Console.WriteLine(person.Name); } } ``` 这里,我们使用了一个匿名类型作为分组的键,该匿名类型包含Age和City属性。GroupBy方法返回一个IEnumerable<IGrouping<TKey, TElement>>类型的对象,其中TKey是匿名类型,而TElement是分组中的元素。我们使用foreach循环遍历分组后的结果,并打印出每个分组的Age和City属性以及分组中的元素。
相关问题

C# list根据多个列分组,并计算每个分组的数量

你可以使用 LINQ 查询来实现根据多个列分组并计算每个分组的数量。以下是一个示例代码: ```csharp var myList = new List<MyClass>(); // 假设 MyClass 有三个属性:Name、Age 和 Gender var result = myList.GroupBy(x => new { x.Name, x.Age, x.Gender }) .Select(g => new { g.Key.Name, g.Key.Age, g.Key.Gender, Count = g.Count() }) .ToList(); ``` 这段代码将 `myList` 按照 `Name`、`Age` 和 `Gender` 三个属性进行分组,并计算每个分组的数量。最终的结果是一个匿名对象的列表,包含了分组的三个属性和每个分组的数量。

C# 对象集合 多字段去重

C# 中可以使用 Linq 的 Distinct 方法进行集合去重,但是默认情况下 Distinct 只能根据元素的值进行比较,无法根据多个字段进行比较。 要实现多字段去重,可以使用 Linq 的 GroupBy 方法先按照指定字段进行分组,然后再取每组的第一个元素,即可实现多字段去重。 示例代码如下: ```csharp class Person { public string Name { get; set; } public int Age { get; set; } public string Address { get; set; } } List<Person> persons = new List<Person> { new Person { Name = "Tom", Age = 18, Address = "Beijing" }, new Person { Name = "Jack", Age = 20, Address = "Shanghai" }, new Person { Name = "Tom", Age = 18, Address = "Beijing" }, new Person { Name = "Tom", Age = 22, Address = "Shenzhen" }, new Person { Name = "Mike", Age = 20, Address = "Shanghai" } }; var distinctPersons = persons.GroupBy(p => new { p.Name, p.Age, p.Address }) .Select(g => g.First()) .ToList(); ``` 上述代码中,首先定义了一个 Person 类,包含了三个字段:Name、Age 和 Address。然后创建了一个包含了几个 Person 对象的 List。 接下来使用 Linq 的 GroupBy 方法将 Person 对象按照 Name、Age 和 Address 进行分组,得到一个键值对集合,其中键为一个包含三个字段的匿名类型对象,值为该分组下的所有 Person 对象。然后使用 Select 方法取每个分组的第一个元素,即可得到去重后的 Person 集合。最后通过 ToList 方法将结果转换为 List。

相关推荐

最新推荐

recommend-type

C# List实现行转列的通用方案

本篇通过行转列引出了System.Linq.Dynamic,并且介绍了过滤功能,具有很好的参考价值。下面跟着小编一起来看下吧
recommend-type

C#多线程处理多个队列数据的方法

主要介绍了C#多线程处理多个队列数据的方法,涉及C#线程与队列的相关操作技巧,需要的朋友可以参考下
recommend-type

C#重定义的下拉多选控件,支持显示多列、单选/多选,文件中附有源码

③,在下拉列表中可显示自定义的多列数据。④,可在下拉列表中通过输入关键字,自动搜索符合条件的数据行。⑤,可指定不同的值列和显示列。⑥,可设置是否显示行头和列头。⑦,程序根据显示列的多少和宽度,自动调整...
recommend-type

C#遍历List并删除某个元素的方法

主要介绍了C#遍历List并删除某个元素的方法,实例分析了正序与倒序遍历list及删除元素的使用技巧,需要的朋友可以参考下
recommend-type

C#中GridView动态添加列的实现方法

主要介绍了C#中GridView动态添加列的实现方法,涉及C#中GridView的相关使用技巧,具有一定参考借鉴价值,需要的朋友可以参考下
recommend-type

zigbee-cluster-library-specification

最新的zigbee-cluster-library-specification说明文档。
recommend-type

管理建模和仿真的文件

管理Boualem Benatallah引用此版本:布阿利姆·贝纳塔拉。管理建模和仿真。约瑟夫-傅立叶大学-格勒诺布尔第一大学,1996年。法语。NNT:电话:00345357HAL ID:电话:00345357https://theses.hal.science/tel-003453572008年12月9日提交HAL是一个多学科的开放存取档案馆,用于存放和传播科学研究论文,无论它们是否被公开。论文可以来自法国或国外的教学和研究机构,也可以来自公共或私人研究中心。L’archive ouverte pluridisciplinaire
recommend-type

实现实时数据湖架构:Kafka与Hive集成

![实现实时数据湖架构:Kafka与Hive集成](https://img-blog.csdnimg.cn/img_convert/10eb2e6972b3b6086286fc64c0b3ee41.jpeg) # 1. 实时数据湖架构概述** 实时数据湖是一种现代数据管理架构,它允许企业以低延迟的方式收集、存储和处理大量数据。与传统数据仓库不同,实时数据湖不依赖于预先定义的模式,而是采用灵活的架构,可以处理各种数据类型和格式。这种架构为企业提供了以下优势: - **实时洞察:**实时数据湖允许企业访问最新的数据,从而做出更明智的决策。 - **数据民主化:**实时数据湖使各种利益相关者都可
recommend-type

解释minorization-maximization (MM) algorithm,并给出matlab代码编写的例子

Minorization-maximization (MM) algorithm是一种常用的优化算法,用于求解非凸问题或含有约束的优化问题。该算法的基本思想是通过构造一个凸下界函数来逼近原问题,然后通过求解凸下界函数的最优解来逼近原问题的最优解。具体步骤如下: 1. 初始化参数 $\theta_0$,设 $k=0$; 2. 构造一个凸下界函数 $Q(\theta|\theta_k)$,使其满足 $Q(\theta_k|\theta_k)=f(\theta_k)$; 3. 求解 $Q(\theta|\theta_k)$ 的最优值 $\theta_{k+1}=\arg\min_\theta Q(
recommend-type

JSBSim Reference Manual

JSBSim参考手册,其中包含JSBSim简介,JSBSim配置文件xml的编写语法,编程手册以及一些应用实例等。其中有部分内容还没有写完,估计有生之年很难看到完整版了,但是内容还是很有参考价值的。