[英]Need a linq to objects query for a nested collection
我正在嘗試從四個深度中的三個集合中選擇文本。
RootObject
有一個List<ResourceSet>
resourceSets
resourceSets
有一個List<Resources>
resources
resources
有一個List<RouteLeg>
routeLegs
所述routLegs
具有List<ItineraryItem>
itineraryItems
每個routeLeg
包含名為ItineraryItem
對象,在該對象中有一個text屬性。
我試圖拉出routeLeg
對象上所有文本屬性的routeLeg
。 正如你所看到的,它嵌套得非常深。 我顯然可以在嵌套循環中執行此操作..(如下所示)但是想要使用Linq to Objects更清潔,但是我遇到了多重嵌套問題。
ResourceSet testst = new ResourceSet();
ResourceSet rs;
StringBuilder sb = new StringBuilder();
for (int i = 0; i < _Result.resourceSets.Count; i++)
{
rs = _Result.resourceSets[i];
for (int j = 0; j < rs.resources.Count; i++)
{
Resource rec = rs.resources[j];
string test = rec.distanceUnit;
for (int k = 0; k < rec.routeLegs.Count; k++)
{
RouteLeg rl = rec.routeLegs[k];
for (int l = 0; l < rl.itineraryItems.Count; l++)
{
ItineraryItem ii = rl.itineraryItems[l];
sb.Append(ii.instruction.ToString());
}
}
}
}
您可以使用SelectMany來獲取內部項:
var items = result.resourceSets
.SelectMany(rs => rs.resources)
.SelectMany(res => res.routeLegs)
.SelectMany(rl => rl.itineraryItems)
foreach(var x in items)
sb.Append(x.instruction.ToString());
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.