我有一个类的通用列表,我可以使用Reflection和扩展方法将其自动转换为DataTable。现在我想反向进行操作。我想将DataTable转换为List。期望一个DataTableType并根据列名自动查找该类型(class)的属性并将值分配给该Type(class)的对象。像这样的psodu代码:

private List<T> ConvertToList<T>(DataTable dt)
{
    List<string> AllColumns = // Get All Column Names of a DataTable
    for(int i=0;i<dt.Rows.Count;i++)
    {
        foreach(var item in AllColumns )
        {
             //Get Property According To **ITEM**
             //Get Data Of Rows[i][item] and assign it to T.property
        }
    }
}

我该怎么做?

编辑1)

我这样使用@Cuong Le的答案:
var properties = typeof(CustomType).GetProperties().ToList();
List<CustomType> list = ConvertToList<CustomType>(dt, properties);

和 :
private List<T> ConvertToList<T>(DataTable dt,List<PropertyInfo> fields) where T : class
{
    return dt.AsEnumerable().Select(Convert<T>(fields)).ToList();  <------
}

private T Convert<T>(DataRow row,List<PropertyInfo> fields) where T : class
{
    var properties = typeof(T).GetProperties().ToList();

    var objT = Activator.CreateInstance<T>();
    foreach (var pro in properties)
    {
        pro.SetValue(objT, row[pro.Name],null);
    }

    return objT;
}

但在一行中,我在其前面放了一个箭头,但出现了两个错误:







我该如何解决这个问题?

最佳答案

使用AsEnumerable()方法支持LINQ:

    private List<T> ConvertToList<T>(DataTable dt)
    {
        var columnNames = dt.Columns.Cast<DataColumn>()
            .Select(c => c.ColumnName)
            .ToList();

        var properties = typeof(T).GetProperties();

        return dt.AsEnumerable().Select(row =>
            {
                var objT = Activator.CreateInstance<T>();

                foreach (var pro in properties)
                {
                    if (columnNames.Contains(pro.Name))
                        pro.SetValue(objT, row[pro.Name]);
                }

                return objT;
            }).ToList();

    }



此处的链接:http://msdn.microsoft.com/en-us/library/kyaxdd3x.aspx

关于c# - 如何使用反射将DataTable转换为List <T>,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/12662318/

10-16 23:05