如何在运行时在IEnumerable 上创建动态选择?

鉴于我有一个IEnumerable ,其中T是任何对象,我如何从中选择一个特定的属性,因为我知道运行时其中一个属性名称的名称是一个字符串?

例如:

 var externalIEnumerable = DataPassedFromConsumingCode(); // `IEnumerable` string knownPropertyName = "Foo"; var fooSelect = externalIEnumerable.Select(...); 

本质上,我显然只是做了externalIEnumerable.Select(x=> x.Foo); ,但我需要在运行时执行此Select ,当我无法控制它最初创建时。

答案:根据AlanT的回答,这是我实际做的:

 public Expression<Func> SelectExpression(string fieldName) { var param = Expression.Parameter(typeof(TItem), "item"); var field = Expression.Property(param, fieldName); return Expression.Lambda<Func>(field, new ParameterExpression[] { param }); } 

我把它保存为Expression,因为调用Compile导致IQueryable被枚举,这意味着数据库被不必要地命中。 因此,要使用它,我只需执行以下操作:

 string primaryKey = _map.GetPrimaryKeys(typeof(TOriginator)).Single(); var primaryKeyExpression = SelectExpression(primaryKey); var primaryKeyResults = query.Select(primaryKeyExpression).ToList(); 

可以使用Expression执行此操作

例如

 private class Foo { public string Bar { get; set; } } private IEnumerable SomeFoos = new List() { new Foo{Bar = "Jan"}, new Foo{Bar = "Feb"}, new Foo{Bar = "Mar"}, new Foo{Bar = "Apr"}, }; [TestMethod] public void GetDynamicProperty() { var expr = SelectExpression("Bar"); var propValues = SomeFoos.Select(expr); Assert.IsTrue(new[] { "Jan", "Feb", "Mar", "Apr" }.SequenceEqual(propValues)); } public static Func SelectExpression(string fieldName) { var param = Expression.Parameter(typeof(TItem), "item"); var field = Expression.Property(param, fieldName); return Expression.Lambda>(field, new ParameterExpression[] { param }).Compile(); } 

心连心,
艾伦。

动态linq库允许您动态指定谓词和投影,并且可能适合您的用例 –

http://weblogs.asp.net/scottgu/archive/2008/01/07/dynamic-linq-part-1-using-the-linq-dynamic-query-library.aspx

您可以动态构建Expression>