我有一个对象列表,我想将其转换为另一个对象列表。
第一个对象如下所示:
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"}
答案 0 :(得分:8)
使用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)
});
答案 1 :(得分:2)
您可以使用group by
LINQ运算符实现此目的:
var obj2List =
from o in list
group o by o.Name into g
select new ObjectTwo() {Name = g.Key, Items = g.Select(x => x.Item)};