首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >使用lambda查找所有实体

使用lambda查找所有实体
EN

Stack Overflow用户
提问于 2013-01-23 04:18:12
回答 3查看 1.8K关注 0票数 3

我有一个孩子( List<Person> )每个人都有一个孩子( List<Kid> )

如果我想在LINQ中找到所有的孩子,我会这样做

代码语言:javascript
复制
var kids=new List<Kids>();

foreach(var p in people)
{
    foreach(var kid in p.Kids)
    {
         kids.Add(kid);
    }
}

有没有一种使用LINQ来做这件事的方法?

EN

回答 3

Stack Overflow用户

回答已采纳

发布于 2013-01-23 04:20:09

它就像SelectMany一样简单

将序列的每个元素投影到IEnumerable,并将生成的序列展平为一个序列。

代码语言:javascript
复制
var kids = people.SelectMany(p => p.Kids);

(如果您想要List<Kid>而不是IEnumerable<Kid>,只需对结果调用.ToList()。)

票数 13
EN

Stack Overflow用户

发布于 2013-01-23 04:21:04

您可以使用SelectMany扩展方法

代码语言:javascript
复制
var kids = new List(people.SelectMany(person => person.Kids));
票数 4
EN

Stack Overflow用户

发布于 2013-01-23 04:23:15

SelectMany的"LINQ-non-lambda-style“版本

代码语言:javascript
复制
var allKids = 
  from p in people
  from k in p.Kids  // secondary "from" makes SelectMany (aka flat map)
  select k;

// Result from above is IEnumerable, to Force evaluation as a List:
List<Kid> allKidsList = allKids.ToList();
票数 3
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/14467266

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档