繁体   English   中英

这个LINQ可以更高效吗?

[英]Can this LINQ be more efficient?

我有一个相当复杂的linq分组,有些重复让我烦恼,但我无法减少它。 有没有办法避免两次获得ID ==“XYZ”的项目列表?

var example = = new GdsObservableCollection<GroupedQueryResults>(
                items.Where(a => a.SubCategory3 != "{template}")
                     .GroupBy(item => item.SubCategory1)
                     .Select(g => new GroupedQueryResults
                                  {
                                     SubCategory = g.Key,
                                     SectionHeader = (g.Count(x => x.Id == "XYZ") > 0) ?
                                     "Category :" +  g.Where(x => x.Id == "XYZ")
                                                     .First().NewValue :
                                     "Item - " + itemNumber

...

我不会说效率更高,但可以更小一点,因为你可以在AnyFirst使用谓词:

var example = new GdsObservableCollection<GroupedQueryResults>(
            items.Where(a => a.SubCategory3 != "{template}")
                 .GroupBy(item => item.SubCategory1)
                 .Select(g => new GroupedQueryResults
                              {
                                 SubCategory = g.Key,
                                 SectionHeader = g.Any(x => x.Id == "XYZ") ?
                                 "Category :" +  g.First(x => x.Id == "XYZ").NewValue :
                                 "Item - " + itemNumber

通过使用Where + Select + FirstOrDefault链与C#null-coalescing运算符结合,可以避免重复搜索x.Id == "XYZ"

SectionHeader = g
    .Where(x => x.Id == "XYZ")
    .Select(x => "Category :" +  x.NewValue)
    .FirstOrDefault() ?? "Item - " + itemNumber

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM