c# - 集合中的第一个匹配项

标签 c# linq

我想将此代码转换为 linq 解决方案。它的作用是调查一组客户,看看是否至少有一个有中间名。这段代码工作正常,我只是想学习 linq,所以寻找替代解决方案。:

//Customers - List<Customer>
private bool checkMiddleName()
{
    foreach (Customer i in Customers)
    {
        if (i.HasMiddleName == true)
        {
            return true;
        }
    }
    return false;
}

我试着写这样的东西:(Customers.Foreach(x=>x.HasMiddleName==true)... 但看起来这不是我正在寻找的方法。

最佳答案

如果你只想知道是否至少有一个,你可以使用Enumerable.Any:

bool atLeastOneCustomerWithMiddleName = Customers.Any(c => c.HasMiddleName);

如果您想知道第一个匹配的客户,您可以使用Enumerable.FirstEnumerable.FirstOrDefault使用 MiddleName==true 找到第一个客户:

var customer = Customers.FirstOrDefault(c => c.HasMiddleName);
if(customer != null)
{
    // there is at least one customer with HasMiddleName == true
}
如果源序列为空,

First 会抛出 InvalidOperationException,而如果没有匹配项,FirstOrDefault 会返回 null

关于c# - 集合中的第一个匹配项,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/11570283/

相关文章:

javascript - 在 javascript 中使用 C# 正则表达式

c# - 2 个不同类中使用的拥有类型的 EF Core 配置问题

c# - 如何使用 Entity Framework 在具有多个联接的查询中使用可选参数?

c# - LINQ 中的条件和

c# - 我如何从 C# 中的选定内容中排序

c# - 在 ASP.Net 中将数据更新到 SQL Server 的最佳实践是什么

c# - 使用 string.concat 还是 string builder 更好?

c# - FirstOrDefault() 的性能

linq - 可以将多个编译的 linq 查询链接在一起吗?

c# - LINQ to SQL - 跟踪新/脏对象