使用反射从列表中检索值



我有一个简单的方法,可以从 azure 移动服务中检索表。

public static async List<T>GetDataFromListTable<T>()
{
    var data = await MobileService.GetTable<T>().ToListAsync();
    return data.Count != 0 ? data : null;
}

这工作正常。

我正在尝试做的是使用另一个方法,该方法采用从服务返回的参数名称并返回该参数的值。到目前为止,我有这个

public static async Task<T> GetDataFromTable<T>(string paramName)
    {
        var k = Activator.CreateInstance(typeof(T));
        var members = typeof(T).GetProperties().Select(t=>t.Name).ToList();
        if (!members.Contains(paramName))
            return (T)k;
        var mn = typeof(T).GetProperties()[members.IndexOf(paramName)];
        var data = GetDataFromListTable<T>();
        var retval = data.Select(t => t.mn);
    }

问题显然是我无法执行 Linq 查询,因为 T 不包含 mn。我也不能使用

var retval = data.Select(t=>t.paramName);

因为 paramname 只是类中成员的字符串表示形式。

简而言之。。。

方法

1 具有参数名称,从方法 2 中获取一个列表。从方法 2 返回的列表中,找到参数名称并返回关联的值。

有没有办法做我想做的事情?

你可以做:

var retval = data.Select(t => mn.GetGetMethod().Invoke(t, null));

var retval = data.Select(t => mn.GetValue(t, null));

你也可以用这样的东西来简化你的代码(没有测试,对不起):

public static async Task<T> GetDataFromTable<T>(string paramName)
{
    var k = Activator.CreateInstance(typeof(T));
    var mn = typeof(T).GetProperty(paramName);
    if (mn == null)
        return (T)k;
    var data = GetDataFromListTable<T>();
    var retval = data.Select(t => mn.GetGetMethod().Invoke(t, null));
    ...
}

我认为使用表达式树会更方便,因为您正在使用集合。您的方法签名需要合并TTResult类型,因为它使用的是返回IEnumerable<TResult>Select

public static async Task<IEnumerable<TResult>> SelectData<T, TResult>(
    string propertyName
)
{
    if(string.IsNullOrWhiteSpace(propertyName))
    {
        return Enumerable.Empty<TResult>();
    }
    var dataTask = GetTableData<T>();
    var tType = Expression.Parameter(typeof(T), "t");
    var property = Expression.Property(tType, propertyName);
    var selectExpression =
        Expression.Lambda<Func<T, TResult>>(property, tType)
                  .Compile();
    return (await dataTask).Select(selectExpression);
}

难道不可能这样做吗

 var retval =  data.Select(t => mn.GetValue(t, null));

相关内容

  • 没有找到相关文章

最新更新