[英]Can't get right query result that I need
我有一个对象
class item { Guid id; String name; List<item> childs;}
它的数据有两个部分。
咖啡店
- 约翰
- - 框
-罗密欧
和
咖啡店
- 约翰
-罗密欧
- - 框
因此,盒子刚刚更改了它的所有者。
现在,我需要以字符串形式获取此结构。
因此,它必须是:
咖啡馆,约翰,盒子,罗密欧
和
咖啡馆,约翰,罗密欧,盒子
我有代码:
public static IEnumerable<item> get_in_one_row(this IEnumerable<item> itemsTree)
{
return itemsTree.Select(p=>p).Union(itemsTree.SelectMany(p=>p.childs.get_in_one_row()));
}
但是我总是得到:咖啡馆,约翰,罗密欧,盒子-不管谁是盒子的所有者。
我该怎么办?
谢谢。
为了按该顺序获得结果,您需要以另一种方式遍历树:
public static IEnumerable<item> get_in_one_row(this IEnumerable<item> itemsTree)
{
return itemsTree.SelectMany(p => Enumerable.Repeat(p,1).Concat(p.childs.get_in_one_row()));
}
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.