c# - Linq 表到 DataTable 转换

标签 c# linq dataset

如何转换

System.Data.Linq.Table<T>System.Data.DataTable

        DemoDBDataContext context = new DemoDBDataContext();
        DataSet ds = new DataSet();
        var query = context.Customers;   
        ds.Tables[0] = query;

该怎么做?作业

ds.Tables[0] = query;

它抛出

Property or indexer System.Data.DataTableCollection.this[int] cannot be assigned to it is read only.

最佳答案

您不能将 System.Data.Linq.Table 转换为 DataTable,但是您可以轻松地在 IEnumerable 上编写扩展方法以将其转换为 DataTable:

public static DataTable ToDataTable<T>(this IEnumerable<T> items)
{
    var tb = new DataTable(typeof(T).Name);
        PropertyInfo[] props = typeof(T).GetProperties(BindingFlags.Public | BindingFlags.Instance);
    foreach(var prop in props)
    {
        tb.Columns.Add(prop.Name, prop.PropertyType);
    }

    foreach (var item in items)
    {
        var values = new object[props.Length];
        for (var i=0; i<props.Length; i++)
        {
           values[i] = props[i].GetValue(item, null);
        }

        tb.Rows.Add(values);
    }
    return tb;
}

来源:http://www.chinhdo.com/20090402/convert-list-to-datatable/

关于c# - Linq 表到 DataTable 转换,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/1935206/

相关文章:

Linq 与 sum 相交

c# - 使用 Entity Framework 的具有多对多关系的 Linq 查询

python - make_initializable_iterator 和 make_one_shot_iterator 之间的 tensorflow 数据集 API 差异

c# - 从 C# 以编程方式创建快捷方式并设置 "Run as administrator"属性

c# - 从父类型列表中获取派生类型

c# - 如何将 2 层深的 foreach 循环转换为 LINQ 表达式以生成 Dictionary<string,SomeList<Item>>?

asp.net - 将数据集导出到 Excel 并从 asp.net Web 方法引发文件下载对话框

c# - LibUsbDotNet 调用 UsbDevice.AllDevices 时找不到设备

c# - 以反向模式运行 MongoDB 集合

C# WinForms - 如何将更新从 DataGridView 发送到数据库