使用linq将通用列表转换为datatable ..?

时间:2013-02-21 14:03:45

标签: c# linq linq-to-dataset

List<Employee> objEmpList = new List<Employee>();
    for (int i = 0; i < 5; i++)
    { 
        objEmpList.Add(new Employee(){ID=i, Name="aa" + i});
    }

我想使用linq或lambda表达式创建具有通用列表项的表作为行...如何做到这一点.. ??我使用循环做了那个但我想用linq做那个..!

1 个答案:

答案 0 :(得分:9)

使用CopyToDataTable扩展名。请参阅msdn文章How to: Implement CopyToDataTable Where the Generic Type T Is Not a DataRow

DataTable table = objEmpList.CopyToDataTable();

BTW这里是创建员工列表的简单方法:

Enumerable.Range(0,5)
          .Select(i => new Employee { ID = i, Name = "aa" + i })
          .ToList();

还要考虑使用NBuilder

Builder<Employee>.CreateListOfSize(5).Build()