zoukankan      html  css  js  c++  java
  • DataTable 转换为List 集合

     1 /// <summary>
     2         /// DataTable 转换为List 集合
     3         /// </summary>
     4         /// <typeparam name="TResult">类型</typeparam>
     5         /// <param name="dt">DataTable</param>
     6         /// <returns></returns>
     7         public static List<TResult> ToLists<TResult>(this DataTable dt) where TResult : class, new()
     8         {
     9             //创建一个属性的列表
    10             List<PropertyInfo> prlist = new List<PropertyInfo>();
    11             //获取TResult的类型实例  反射的入口
    12             Type t = typeof(TResult);
    13             //获得TResult 的所有的Public 属性 并找出TResult属性和DataTable的列名称相同的属性(PropertyInfo) 并加入到属性列表 
    14             Array.ForEach<PropertyInfo>(t.GetProperties(), p => { if (dt.Columns.IndexOf(p.Name) != -1) prlist.Add(p); });
    15             //创建返回的集合
    16             List<TResult> oblist = new List<TResult>();
    17 
    18             foreach (DataRow row in dt.Rows)
    19             {
    20                 //创建TResult的实例
    21                 TResult ob = new TResult();
    22                 //找到对应的数据  并赋值
    23                 prlist.ForEach(p => { if (row[p.Name] != DBNull.Value) p.SetValue(ob, row[p.Name], null); });
    24                 //放入到返回的集合中.
    25                 oblist.Add(ob);
    26             }
    27             return oblist;
    28         }
  • 相关阅读:
    Vmware安装Ubuntu ==> 连网成功
    在 ns3.25中添加 plc(电力线载波) 模块
    Ubuntu12.04下安ns3.29及Ubuntu换源方法
    微信支付小程序版
    微信小程序打开外部链接
    linux下安装Mongodb
    延迟执行+异步 之代码分析1
    Vue入门
    实验一
    实验二
  • 原文地址:https://www.cnblogs.com/lyboke/p/15157627.html
Copyright © 2011-2022 走看看