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 查询以返回具有特定属性值的嵌套数组的主要内容,如果未能解决你的问题,请参考以下文章

如何使用 linq 查询具有嵌套列表的对象?

具有多重嵌套表的分组方式和计数作为 LINQ 查询

通过Linq查询从双值的元组返回一个List

如何返回具有特定字段值的所有数据库行

csharp 使用LINQ检查列表中的项是否具有其属性之一的特定值,第二种方式使用“out”修饰符来返回va

使用 LINQ 从具有嵌套数组的类中获取子属性值和父属性值