我有一个对象列表,我想将其转换为另一个对象列表.
第一个对象如下所示:
private class ObjectOne { public string Name { get; set; } public string Item{ get; set; } }
而另一个像这样
public class ObjectTwo { public string Name { get; set; } public IEnumerable<string> Items{ get; set; } }
我想编写一个linq查询或lambda表达式,它可以将ObjectOne数据列表转换为ObjectTwo数据列表. ObjectTwo列表中的每个项目都将包含ObjectOne中的不同名称,以及与该名称关联的所有项目的枚举.
例如,以下ObjectOne数据列表
"Name One","Item One" "Name One","Item Two" "Name Two","Item Three"
会产生以下ObjectTwo列表:
"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) });