8

オブジェクトがあるIEnumerable<T>場合T、実行時にプロパティ名の1つの名前を文字列として知っている場合、そのオブジェクトから特定のプロパティを選択するにはどうすればよいですか?

例えば:

var externalIEnumerable = DataPassedFromConsumingCode(); // `IEnumerable<T>`

string knownPropertyName = "Foo";
var fooSelect = externalIEnumerable.Select(...);

本質的に、私は明らかに実行しているだけですが、最初に作成されるタイミングを制御できない場合は、実行時にexternalIEnumerable.Select(x=> x.Foo);これを実行する必要があります。Select

-

回答: AlanTの回答に基づいて、私が実際に行ったことは次のとおりです。

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

呼び出すCompileとIQueryableが列挙され、データベースが不必要にヒットしたため、式として保持しました。それで、それを使うために、私はただ次のことをします:

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

3 に答える 3

7

式を使用してこれを行うことが可能です

例えば

private class Foo {
    public string Bar { get; set; }
}

private IEnumerable<Foo> SomeFoos = new List<Foo>() {
    new Foo{Bar = "Jan"},
    new Foo{Bar = "Feb"},
    new Foo{Bar = "Mar"},
    new Foo{Bar = "Apr"},
};

[TestMethod]
public void GetDynamicProperty() {

        var expr = SelectExpression<Foo, string>("Bar");
        var propValues = SomeFoos.Select(expr);

        Assert.IsTrue(new[] { "Jan", "Feb", "Mar", "Apr" }.SequenceEqual(propValues));

    }

public static Func<TItem, TField> SelectExpression<TItem, TField>(string fieldName) {

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

}

hth、
アラン。

于 2012-01-24T16:33:54.327 に答える
0

動的なlinqライブラリを使用すると、述語と射影をその場で指定でき、ユースケースに適合する場合があります-

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

于 2012-01-24T16:34:48.583 に答える
0

を動的に作成できますExpression<Func<T, U>>

于 2012-01-24T16:34:51.120 に答える