我正在尝试执行以下操作
string orderedBy = "item.length";
var sorted = from PPart item in partList
orderby orderedBy
select item;
其中partList是包含PPart类型对象的数组列表。上面的语句没有对arrayList进行排序。
如果我直接在linq查询中写入item.length,如下所示,则列表正在排序
var sorted = from PPart item in partList
orderby item.length
select item;
如何使动态linq与后期绑定一起使用
答案 0 :(得分:1)
您可以使用表达式树来执行此操作,例如:
public static Func<PPart, IComparable> GetOrderByPropertyExpression(string propertyName)
{
ParameterExpression parameter = Expression.Parameter(typeof (PPart));
PropertyInfo baseProperty = typeof (PPart).GetProperty(propertyName);
Expression memberExpression = Expression.Property(parameter, baseProperty);
return
Expression.Lambda<Func<PPart, IComparable>>(Expression.TypeAs(memberExpression, typeof (IComparable)),
parameter).Compile();
}
并使用如下:
IOrderedEnumerable<PPart> ordered = partList.OrderBy(PPart.GetOrderByPropertyExpression("length"));
没有提供错误检查,只是一个概念。