Как можно изменить оператор 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();
}
}