我有这样的课程:
public class SomeClass
{
public string Text1 { get; set; }
public string Text2 { get; set; }
public int Number { get; set; }
}
我有这个类对象的列表:
List<SomeClass> myList = new List<SomeClass>();
我想使用LINQ(lambda语法)查询此列表:
var result = myList.Where(obj => obj.Text1 == "SomeString");
有没有办法传递属性(例如,通过字符串名称),我希望通过它来执行此LINQ查询?在这个例子中,我按Text1属性搜索,但是假设我想在Text1或Text2上动态调用此搜索(在运行时确定)。我希望能够传递执行此搜索的属性名称,并检查此属性是否为字符串,以便我确定可以首先执行此搜索。
这可能吗?我知道思考和表达有关于它的事情,但我不太了解它们。
由于
答案 0 :(得分:1)
使用反射的方法:
var result = myList.Where(obj => obj.GetType()
.GetProperty("Text1")
.GetValue(obj)
.Equals("SomeString"));
通过这种方式,您可以从"Text1"
更改为"Text2"
属性。
您可以使用dynamic linq的另一种方法:
var result = myList.AsQueryable().Where("Text1=@0", "SomeString");
动态LINQ也可通过nuget获得。
答案 1 :(得分:1)
你可以使用表达式树吗?
string memberName = "Text1", value = "SomeString";
var p = Expression.Parameter(typeof(SomeClass), "obj");
var predicate = Expression.Lambda<Func<SomeClass, bool>>(
Expression.Equal(
Expression.PropertyOrField(p, memberName),
Expression.Constant(value,typeof(string))
), p);
var result = myList.AsQueryable().Where(predicate);
或替代最后一行:
var result = myList.Where(predicate.Compile());