[英]Linq select where in list
我有以下课程
public class Group
{
public string Id { get; set; }
public string Name { get; set; }
}
和2个列表List<string> groupRestrict
和List<Group> groups
现在,组列表包含一些填充了所有字段的组,并且我想选择所有受限组,groupRestrict列表仅包含组的名称。
我尝试了一些操作,但是由于某些原因,它总是返回一个空列表。 这是我的最后一次测试:
var lst = groups.Where(j => groupRestrict.Contains(j.Name)).ToList();
任何线索可能出什么事了吗?
编辑:就像评论说的那样,这本来应该起作用,只是输入中带有一些'
但现在我希望groupRestrict不必是确切的名称,而是可以使用'like'功能。
当前表达式:
var restrictedGroups = (from gr in groupRestrict join g in groups on gr equals g.Name select g).ToList();
尝试:
var lst = groups.Where(j => groupRestrict.Any(x=> j.Name.Contains(x))).ToList();
这将匹配名称包含searchList中一个或多个字符串的所有组。
不区分大小写的变体为:
var lst = groups.Where(j => groupRestrict.Any(x=> j.Name.ToLower().Contains(x.ToLower()))).ToList();
尽管在这种情况下,在查询之前将groupRestrict转换为小写会更好,并且您可以省略x的.ToLower()调用:
string[] lowerCaseGroupRestrict = groupRestrict.Select(x=> x.ToLower()).ToArray();
var lst = groups.Where(j => lowerCaseGroupRestrict.Any(x=> j.Name.ToLower().Contains(x))).ToList();
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.