Linq 查询以返回具有特定属性值的嵌套数组
Posted
技术标签:
【中文标题】Linq 查询以返回具有特定属性值的嵌套数组【英文标题】:Linq Query to Return Nested Arrays having specific Property Value 【发布时间】: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 个的结果只有一个? 抱歉,我从我的问题中删除了我的代码示例,因为它实际上根本不起作用。不过豪伊明白了! 【参考方案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 你能看看这个吗:***.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")))
【讨论】:
很抱歉,来不及了,下次我会做的;)以上是关于Linq 查询以返回具有特定属性值的嵌套数组的主要内容,如果未能解决你的问题,请参考以下文章