linq string.contains в поле списка дочерних объектов - PullRequest
4 голосов
/ 08 декабря 2011

Как можно изменить оператор linq, чтобы он нашел компании, в которых содержится пользователь, с подстрокой «третий»?

В настоящий момент он работает только при поиске полного имени пользователя, то есть содержит («третий пользователь»), потому что он ищет совпадение в списке, а не в строке.

class Company
{
    public Company(List<User> users) { this.Users = users; }
    public List<User> Users { get; set; }
}

class User
{
    public User(string name) { this.Name = name; }
    public string Name { get; set; }
}

class Program
{
    static void Main(string[] args)
    {
        List<Company> companies = new List<Company>();
        Company company1 = new Company(new List<User>(){ new User("first user"), new User("second user") });
        Company company2 = new Company(new List<User>() { new User("third user"), new User("fourth user") });
        companies.Add(company1);
        companies.Add(company2);

        companies = companies
                            .Where(company => company.Users.Select(user => user.Name)
                            .Contains("third")).ToList();
    }
}

1 Ответ

3 голосов
/ 08 декабря 2011

Вы должны позвонить string.Contains на user.Name:

companies = companies
    .Where(company => company.Users.Any(user => user.Name.Contains("third")))
    .ToList();

Посмотреть, как работает онлайн: ideone

...