6

这个问题涉及泛型和类型以及数据表。

以下代码片段遍布网络各处,并基于泛型类型创建数据表:

public static DataTable ListToDataTable<T>(List<T> list)
{
    DataTable dt = new DataTable();

    foreach (PropertyInfo info in typeof(T).GetProperties())
    {
        dt.Columns.Add(new DataColumn(info.Name, info.PropertyType));
    }
    foreach (T t in list)
    {
        DataRow row = dt.NewRow();
        foreach (PropertyInfo info in typeof(T).GetProperties())
        {
            row[info.Name] = info.GetValue(t, null);
        }
        dt.Rows.Add(row);
    }
    return dt;
}

我正在使用出色的 FileHelpers 库将批量记录导入 SQL Server。要使用 SqlBulkCopy,我需要一个包含给定类型列的数据表。Filehelpers 可以在运行时读取 .cs 文件并基于该文件创建您的类型。例如:

System.Type userType = null;
userType = ClassBuilder.ClassFromSourceFile("myclassfile.cs");

我想更改上面的方法,以便在传递类型(例如'userType')时为我创建列。即方法签名将类似于:

public static DataTable TypeToDataTable<T>(<T> myType)

并将返回一个带有列的空数据集,准备好将 userType 行添加到其中。

我尝试了各种方法 - 有什么想法吗?

4

2 回答 2

13

当您意识到在这种情况下不需要(甚至可以)使用泛型时,这实际上非常简单:

public static DataTable CreateEmptyDataTable(Type myType)
{
    DataTable dt = new DataTable();

    foreach (PropertyInfo info in myType.GetProperties())
    {
        dt.Columns.Add(new DataColumn(info.Name, info.PropertyType));
    }

    return dt;
}

你可以这样称呼它:

System.Type userType = null;
userType = ClassBuilder.ClassFromSourceFile("myclassfile.cs");
DataTable emptyDataTable = CreateEmptyDataTable(userType);
于 2011-06-09T10:26:32.220 回答
6

最近我正是需要这个,并在 SO 上找到它。我将问题中的前提与答案结合起来,并决定分享代码,因为两者都不完整:

private DataTable CreateDataTableFromObjects<T>(List<T> items, string name = null)
{
    var myType = typeof(T);
    if (name == null)
    {
        name = myType.Name;
    }
    DataTable dt = new DataTable(name);
    foreach (PropertyInfo info in myType.GetProperties())
    {
        dt.Columns.Add(new DataColumn(info.Name, info.PropertyType));
    }
    foreach (var item in items)
    {
        DataRow dr = dt.NewRow();
        foreach (PropertyInfo info in myType.GetProperties())
        {
            dr[info.Name] = info.GetValue(item);
        }
        dt.Rows.Add(dr);
    }
    return dt;
}
于 2017-04-03T14:50:37.907 回答