如何解决选择列表的内部对象
我的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));
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。