我有一个对象列表,我想将其转换为另一个对象列表.
第一个对象如下所示:@H_502_3@
- private class ObjectOne
- {
- public string Name { get; set; }
- public string Item{ get; set; }
- }
而另一个像这样@H_502_3@
- public class ObjectTwo
- {
- public string Name { get; set; }
- public IEnumerable<string> Items{ get; set; }
- }
我想编写一个linq查询或lambda表达式,它可以将ObjectOne数据列表转换为ObjectTwo数据列表. ObjectTwo列表中的每个项目都将包含ObjectOne中的不同名称,以及与该名称关联的所有项目的枚举.@H_502_3@
例如,以下ObjectOne数据列表@H_502_3@
- "Name One","Item One"
- "Name One","Item Two"
- "Name Two","Item Three"
会产生以下ObjectTwo列表:@H_502_3@
- "Name One",{"Item One","Item Two"}
- "Name Two",{"Item Three"}
解决方法
使用GroupBy Linq运算符.然后,对于每个分组,选择密钥(您用于对其进行分组的密钥),并将每个组的项目转换为列表.
- var oneList = new List<ObjectOne>
- {
- new ObjectOne {Name = "Name One",Item = "Item One"},new ObjectOne {Name = "Name One",Item = "Item Two"},new ObjectOne {Name = "Name Two",Item = "Item Three"}
- };
- var twoList= oneList.GroupBy(x => x.Name)
- .Select (x => new ObjectTwo
- {
- Name = x.Key,Items = x.Select(t => t.Item)
- });