c# – 需要linq to objects查询嵌套集合

c# – 需要linq to objects查询嵌套集合,第1张

概述我正在尝试从四个深度中的三个集合中选择文本. RootObject具有List< ResourceSet> resourceSets resourceSets有一个List< Resources>资源 资源有一个List< RouteLeg> routeLegs routLegs具有List< ItineraryItem> itineraryItems 每个routeLeg包含名为Itinerar 我正在尝试从四个深度中的三个集合中选择文本.

RootObject具有List< ResourceSet> resourceSets

resourceSets有一个List< Resources>资源

资源有一个List< RouteLeg> routeLegs

routLegs具有List< ItineraryItem> itineraryItems

每个routeLeg包含名为ItineraryItem的对象,在该对象中有一个text属性.

我试图拉出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());
总结

以上是内存溢出为你收集整理的c# – 需要linq to objects查询嵌套集合全部内容,希望文章能够帮你解决c# – 需要linq to objects查询嵌套集合所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/langs/1242384.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-06-06
下一篇 2022-06-06

发表评论

登录后才能评论

评论列表(0条)

保存