【问题标题】:Linq Query to Return Nested Arrays having specific Property ValueLinq 查询以返回具有特定属性值的嵌套数组
【发布时间】:2022-01-01 22:09:59
【问题描述】:

我一直在搜寻多种资源,但无法弄清楚这一点;我正在尝试基于嵌套几级的属性来过滤对象数组。我已经简化了一些事情,所以假设我有以下类:

class A {
  B[] bb;
}

class B 
  C[] cc;
}

class C {
  string value;
}

现在是代码:

A[] aa = ...;
A[] filteredAa = aa.Where(... //NEED HELP HERE

我想要做的是过滤 aa 数组,使其只给我那些具有至少一个 B 元素且具有至少一个 C 元素的 A 元素的值为“hello”(例如 aa[0] 将如果 aa[0].bb[3].cc[2].value = "hello") 被包含在 filtersAa 数组中。

甚至可以进行这种类型的过滤吗?我认为并希望这是有道理的,但如果我能进一步澄清,请告诉我。

【问题讨论】:

  • 有什么问题?没有结果?一个错误?应该有 20 个的结果只有一个?
  • 抱歉,我从我的问题中删除了我的代码示例,因为它实际上根本不起作用。不过豪伊明白了!

标签: c# arrays linq properties nested


【解决方案1】:

您需要使用Any - 听起来您需要使用两次:

var query = aa.Where(a => a.bb.Any(b => b.cc.Any(c => c.value == "hello")));

所以从内部开始:

  • 如果C 对象的值为“hello”,则它很有用
  • 如果B 对象的任何C 值有用,则该对象很有用
  • 如果A 对象的任何B 值有用,则该对象很有用
  • Where 过滤一系列 A 对象,只留下有用的对象

如果您真的想要一个数组,可以在末尾使用ToArray(),但我通常会使用ToList,或者将其保留为IEnumerable<A>

【讨论】:

  • 很好的解释,真的把 Any() 方法放到了上下文中——没想到这么简单。
  • 我怎样才能从 A 和 C 中获得价值,例如 ....Select(d => new {a.A, c.C})
  • @SZT:我需要知道确切的细节;这听起来不太适合这个问题,这个问题更多的是关于存在而不是投射。我建议您提出一个包含所有相关详细信息的新问题和minimal reproducible example
  • @JonSkeet 你能看看这个吗:stackoverflow.com/q/69828436/713847
  • @SZT:鉴于您使用的是 LINQ to SQL,答案将取决于了解它支持什么;恐怕已经好几年没用了。
【解决方案2】:

试试这个:

A[] filteredAa = aa.Where(a => a.bb.Any(b => b.cc.Any(c => c.value == "hello"))).ToArray();

【讨论】:

    【解决方案3】:

    如果您正在寻找 Value 是一个特定值的位置:

    var result = aa.Where(a=>a.bb.Any(b => b.cc.Any(c => c.Value == "hello"));
    

    如果你只想获得所有有价值的东西:

    var result = aa.Where(a=>a.bb.Any(b => b.cc.Any(c => !string.IsNullOrEmpty(c.Value)));
    

    【讨论】:

    • +1 我喜欢这个,因为它使用了它不为空的地方而不是你好,因为他最初的(未经编辑的)问题要求结果存在价值而不是价值是你好
    【解决方案4】:
    filteredAa = aa.Where(x => x.bb.Any(y => y.cc.Any(z => z.value == "hello")))
    

    【讨论】:

    • 很抱歉,来不及了,下次我会做的;)
    猜你喜欢
    • 2021-07-16
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2021-11-06
    • 1970-01-01
    相关资源
    最近更新 更多