IEnumerable<T>类型直接转换成DataTable

11 篇文章 0 订阅
3 篇文章 0 订阅

RT,直接上代码


public static class IEnumerableExtensions
   {
       public static DataTable AsDataTable<T>(this IEnumerable<T> data)
       {
           PropertyDescriptorCollection properties = TypeDescriptor.GetProperties(typeof(T));
           var table = new DataTable();
           foreach (PropertyDescriptor prop in properties)
               table.Columns.Add(prop.Name, Nullable.GetUnderlyingType(prop.PropertyType) ?? prop.PropertyType);
           foreach (T item in data)
           {
               DataRow row = table.NewRow();
               foreach (PropertyDescriptor prop in properties)
                   row[prop.Name] = prop.GetValue(item) ?? DBNull.Value;
               table.Rows.Add(row);
           }
           return table;
       }
   }


  • 2
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Datatable类型不能使用AsEnumerable()方法的原因已经在上面回答过了。下面是一些解决方案及代码: 1. 使用DataTableExtensions类中的方法进行Linq查询,例如CopyToDataTable()、AsDataView()等。 代码示例: ```csharp using System.Data; using System.Linq; ... // 创建一个DataTable对象 DataTable dt = new DataTable(); // 添加列 dt.Columns.Add("Id", typeof(int)); dt.Columns.Add("Name", typeof(string)); dt.Columns.Add("Age", typeof(int)); // 添加数据 dt.Rows.Add(1, "Tom", 18); dt.Rows.Add(2, "Jerry", 20); dt.Rows.Add(3, "Lucy", 22); // 使用DataTableExtensions类中的CopyToDataTable()方法进行Linq查询 var result = dt.AsEnumerable().Where(r => r.Field<int>("Age") > 20).CopyToDataTable(); // 输出结果 foreach (DataRow row in result.Rows) { Console.WriteLine(row["Id"] + "\t" + row["Name"] + "\t" + row["Age"]); } ``` 2. 将DataTable类型换为IEnumerable类型,再使用AsEnumerable()方法进行Linq查询。 代码示例: ```csharp using System.Data; using System.Linq; ... // 创建一个DataTable对象 DataTable dt = new DataTable(); // 添加列 dt.Columns.Add("Id", typeof(int)); dt.Columns.Add("Name", typeof(string)); dt.Columns.Add("Age", typeof(int)); // 添加数据 dt.Rows.Add(1, "Tom", 18); dt.Rows.Add(2, "Jerry", 20); dt.Rows.Add(3, "Lucy", 22); // 将DataTable类型换为IEnumerable类型 IEnumerable<DataRow> rows = dt.Rows.Cast<DataRow>(); // 使用AsEnumerable()方法进行Linq查询 var result = rows.AsEnumerable().Where(r => r.Field<int>("Age") > 20); // 输出结果 foreach (DataRow row in result) { Console.WriteLine(row["Id"] + "\t" + row["Name"] + "\t" + row["Age"]); } ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值