选择列表的内部对象

问题描述

我的Project对象中具有以下层次结构

  • 项目
    • 启动
      • 阶段
        • 位置

我将它们包含如下:

 - Project has List<Launch>
 - Launch has List<Phase>
 - Phase has List<Position>

我想用Phase搜索Position.Id = 123对象。我希望仅返回符合条件的第一个对象,即Phase对象。我尝试执行以下操作,但它返回IEnumerable,并且无法直接转换为Phase对象。任何帮助表示赞赏。谢谢

var var_phase = project.Launches
    .Select(l => l.Phases.FirstOrDefault(phase => phase.Positions.Any(p => p.Id == 123)));

解决方法

首先,我们希望将Phases作为 flat (不是分层)IEnumerable<Phase>;我们可以借助SelectMany来做到这一点:

   var allPhases = project
     .Launches
     .SelectMany(launch => launch.Phases);

然后我们可以在Where的帮助下过滤这些阶段:

   var result = project
     .Launches
     .SelectMany(launch => launch.Phases)
     .Where(phase => phase.Positions.Any(position => position.Id == 123));

编辑:如果您只想一个{em} {em} {em} {em} {em} {em} {em}而不是Phase

null
,

您可以使用Enumerable.SelectMany method将结果序列展平为一个序列。

project
    .Launches
    .SelectMany(x => x.Phases)
    .Where(x => x.Positions.Any(p => p.Id == 123));