在我的'Person'课程中,我有一些字段,如'firstname','lastname','nickname'等。
我想编写动态搜索的代码,有时候是'firstname',有时是'nickname'字段。
以常规方式,代码将是:
If(SearchBy == "firstname")
{
Person result = ListOfPerson.Where(p => p.firstname== "exp").FirstOrDefault();
}
else If(SearchBy == "nickname")
{
Person result = ListOfPerson.Where(p => p.nickname== "exp").FirstOrDefault();
}
但是我想写的代码应该是这样的:(每次都保存if)
Object someVariable = "firstname";
Person result = ListOfPerson.Where(p => p.someVariable == "exp").FirstOrDefault();
任何人都可以知道它是否可能?
答案 0 :(得分:5)
这样的事情怎么样:
Func<Person, bool> searchDelegate;
switch (searchMode){
case "firstname":
searchDelegate = (p => p.firstname == searchValue);
break;
case "lastname":
searchDelegate = (p => p.lastname == searchValue);
break;
case "nickname":
searchDelegate = (p => p.nickname == searchValue);
break;
default:
throw new Exception("searchMode is invalid");
}
return ListOFPerson.Where(seachDelegate).FirstOrDefault();
答案 1 :(得分:1)
您可以为Where
使用不同的代理:
Person findFirstname = ListOfPerson.Where(p => p.firstname == "exp").FirstOrDefault();
// or
Person findLastname = ListOfPerson.Where(p => p.lastname == "exp").FirstOrDefault();
(注意我已将=
更改为==
)
答案 2 :(得分:1)
你可以使用反射:
object someVariable = "firstname";
var fieldToCheck = person.GetType().GetField(someVariable);
var isEqual = (string)fieldToCheck.GetValue(person) == "MyValue";
答案 3 :(得分:0)
LINQ to Objects就是为了这个用途而开发的:http://msdn.microsoft.com/en-us/library/bb397937.aspx
答案 4 :(得分:0)
dynamic sorting in LINQ上的帖子可能会对您有所帮助,因为原则相似。