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。