我有List<Person>(人)每个人都有List<Kid>(孩子)
如果我想找到所有5岁以下孩子的人,我会做这样的事情
var peopleWithLittleKids=new List<Person>()
foreach(var p in people)
{
foreach(var kid in p.Kids)
{
if(kid.age<5)
{
peopleWithLittleKids.Add(p);
break;
}
}
}
Run Code Online (Sandbox Code Playgroud)
有没有一种方法使用lambda这样做?
假设允许人们拥有一个以上的孩子...... [在此插入政治声明......]
people.Where(p => p.Kids.Any(k => k.age < 5))
Run Code Online (Sandbox Code Playgroud)
您可以使用Enumerable.Where和Any扩展方法:
var peopleWithLittleKids = people.Where(p => p.Kids.Any(k => k.age < 5)).ToList();
Run Code Online (Sandbox Code Playgroud)
请注意,ToList()如果您只是要遍历结果(via foreach),也可以不用,因为这不需要List<T>结果.
此外 - 如果循环方法Person有多个匹配的子项,则循环方法会多次向列表中添加一个.如果要复制此功能,可以通过以下方式:
var peopleWithLittleKidsContainingDuplicates = people
.SelectMany(p => p.Kids.Where(k => k.Age < 5).Select(k => p));
Run Code Online (Sandbox Code Playgroud)
(这可能不是你想要的,也是原版中的一个错误,但这确实与原始代码相符......)
| 归档时间: |
|
| 查看次数: |
95 次 |
| 最近记录: |