C# Linq表到数据表转换

C# Linq表到数据表转换,c#,linq,dataset,C#,Linq,Dataset,如何投 System.Data.Linq.Table至System.Data.DataTable DemoDBDataContext context = new DemoDBDataContext(); DataSet ds = new DataSet(); var query = context.Customers; ds.Tables[0] = query; 怎么做?任务 ds.Tables[0] = query; 它

如何投

System.Data.Linq.Table
System.Data.DataTable

        DemoDBDataContext context = new DemoDBDataContext();
        DataSet ds = new DataSet();
        var query = context.Customers;   
        ds.Tables[0] = query;
怎么做?任务

ds.Tables[0] = query;
它抛出

属性或索引器
System.Data.DataTableCollection。此[int]
不能分配给它,因为它是只读的。


您不能将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;
}
公共静态数据表到数据表(此IEnumerable items)
{
var tb=新数据表(typeof(T).Name);
PropertyInfo[]props=typeof(T).GetProperties(BindingFlags.Public | BindingFlags.Instance);
foreach(道具中的var道具)
{
tb.Columns.Add(prop.Name,prop.PropertyType);
}
foreach(项目中的var项目)
{
var值=新对象[props.Length];

对于(var i=0;iSorry为延迟响应。它正在工作,感谢链接。