如何使用泛型和Linq扩展方法过滤列表?

时间:2011-06-29 15:35:24

标签: c# linq generics reflection filter

我正在尝试为系统编写一个通用的Filter扩展方法,这样我就可以在任何List上调用filter,并传入一个字段名称及其值的字典来过滤。

我目前在我的系统中有每种类型的方法,但我正在尝试合并到一种方法。

这是我到目前为止所做的...简化所以它只是文本搜索:

public static List<T> Filter<T>(this List<T> model, string json)
    {
        JavaScriptSerializer ser = new JavaScriptSerializer();
        Dictionary<string, object> searchFields = (Dictionary<string, object>)ser.DeserializeObject(json);

        foreach (var key in searchFields.Keys)
        {               
            // How do I perform the search?               
        }

        return model;
    }

我当前的过滤器是每个键上的switch语句,并按如下方式检查每个字段:

switch(key) 
{
    case "Description":
        list = list.Where(x => x.Description.ToLower().Contains(searchFields[key].ToString().ToLower())).ToList();
                    break;
}

如何访问通用对象上的属性以对其进行过滤?我假设我需要以某种方式反思,但我不知道语法。

我正在寻找类似的东西:

list = list.where(listobject.getField(key).contains(value))

这可能吗?在此先感谢您的帮助!

2 个答案:

答案 0 :(得分:6)

foreach循环

中尝试类似的内容
 model.Where(m => typeof(T).GetProperty(key).GetValue(m, null)==searchFields[key]);

答案 1 :(得分:0)

foreach (var key in searchFields.Keys)
{               
    model.Where(m => typeof(T).GetProperty(key).GetValue(m, null).Equals(SearchFields[key], StringComparison.OrdianlIgnoreCase);         
}

return model.ToList();