DataTable与List相互转换

  .NET后台数据处理,从数据库中的捞出的数据格式一般是List和DataTable的格式.现在将两种格式相互转换的心得记录下来以便以后查找(直接上代码).

public class ConvertHelper<T> where T : new()
{
  //将DataTable转换为List
  public static List<T> ConvertToList(DataTable dt)
  {
    // 定义集合
    var ls = new List<T>();
    // 获得此模型的类型
    Type type = typeof(T);
    //定义一个临时变量
    string tempName = "";
    //遍历DT数据行
    foreach (DataRow dr in dt.Rows)
    {
      T t = new T();
      //获得此模型的公共属性
      PropertyInfo[] pros = t.GetType().GetProperties();
      //遍历公共属性
      foreach (PropertyInfo p in pros)
      {
        //属性名称传给临时变量
        tempName = p.Name;
        //检查DataTable是否包含此列(列名==对象的属性名)
        if (dt.Columns.Contains(tempName))
        {
          // 判断此属性是否有Setter  
          if (!p.CanWrite) continue;//该属性不可写,直接跳出
          //取出该行该列的值
          object value = dr[tempName];  
          //如果非空,则赋给对象的属性
          if (value != DBNull.Value)
          p.SetValue(t, value, null);
        }
      }
      ls.Add(t);

   }

    return ls;
}

//获取List类型属性
public static List<PropertyInfo> GetPropertyInfo(List<T> tList)
{
  T t = new T();
  PropertyInfo[] tpro = t.GetType().GetProperties();
  return tpro.ToList();
}

//将list转换为DataTable
public static DataTable ConvertToDataTable(List<T> list)
{
  DataTable dt = new DataTable();//初始化DT
  //var arrPro = GetPropertyInfo(list);
  T t = new T();
  var arrPro = t.GetType().GetProperties();
  foreach (PropertyInfo pro in arrPro)
  {
    if (pro.CanWrite)//如果属性可以写入
    dt.Columns.Add(pro.Name, pro.Name.GetType());//DT的添加列
  }
  for (var i = 0; i < list.Count(); i++)
  {
    DataRow newDr = dt.NewRow();
    foreach (PropertyInfo p in arrPro)
    {
      if (p.CanWrite)
      newDr[p.Name] = p.GetValue(list[i]);//新行的列赋值
    }
    dt.Rows.Add(newDr);
  }
  return dt;
 }
}

DataTable和List相互转换的类的更多相关文章

  1. C# 将DataTable数据源转换成实体类

    using System; using System.Collections.Generic; using System.Data; using System.Reflection; /// < ...

  2. DataTable转List<Model>通用类

    /// <summary> /// DataTable转List<Model>通用类[实体转换辅助类] /// </summary> public class Mo ...

  3. DataTable转List<Model>通用类【实体转换辅助类】

    /// <summary> /// DataTable转List<Model>通用类[实体转换辅助类] /// </summary> public class Mo ...

  4. DataReader,DataTable利用泛型填充实体类

    using System; using System.Collections.Generic; using System.Linq; using System.Web; /// <summary ...

  5. C# LINQ系列:LINQ to DataSet的DataTable操作 及 DataTable与Linq相互转换

    LINQ to DataSet需要使用System.Core.dll.System.Data.dll和System.Data.DataSetExtensions.dll,在项目中添加引用System. ...

  6. JSON对象与XML相互转换工具类

    依赖jar <dependency> <groupId>dom4j</groupId> <artifactId>dom4j</artifactId ...

  7. DataTable转List,DataTable转为Model对象帮助类

    DataTable转List,DataTable转为Model对象帮助类 public class ModelConvertHelper<T> where T : new() { publ ...

  8. (转)DataTable与结构不同实体类之间的转换

    原文地址:http://www.cnblogs.com/kinger906/p/3428855.html 在实际开发过程中,或者是第三方公司提供的数据表结构,与我们系统中的实体类字段不对应,遇到这样我 ...

  9. DataTable与结构不同实体类之间的转换

    在实际开发过程中,或者是第三方公司提供的数据表结构,与我们系统中的实体类字段不对应,遇到这样我们怎么处理呢?可能有人会说,在转换时创建一个实体对象,对表里的数据逐行遍历来实例化这个实体对象不就完了.的 ...

随机推荐

  1. Centos6.6 编译安装nginx

    一.基本环境 nginx 1.9版以后增加了一些新的特性,支持tcp负载均衡,不过这次还是用1.8.0,这里面有个memcached的代理模块,有时间再测试下 1.centos6.6 2.nginx1 ...

  2. Arduino 控制超声波测距模块

    一.实物图 二.例子代码 用到数字2 和3 引脚,还有两个就是vcc GND两个阴脚,用模块连线比较简单

  3. Django1.11配合uni-app发起微信支付!

    Django1.11配合uni-app发起微信支付! 经过三天的断断续续的奋战,我终于是干动了微信支付.为了以后不忘记,现在来一篇教程,来来来,开干!!! 一.准备阶段 1.准备阶段我们需要去微信官网 ...

  4. [Ynoi2014]不归之人与望眼欲穿的人们

    题目大意: 给定一个序列,每次单点修改一个数,或给定$x$,询问最短的or起来大于等于$x$的区间的长度(不存在输出-1). 解题思路: 在太阳西斜的这个世界里,置身天上之森.等这场战争结束之后,不归 ...

  5. 自动装箱拆箱(Autoboxing,Unboxing)

    自动装箱和拆箱 https://docs.oracle.com/javase/tutorial/java/data/autoboxing.html 1.5才有(Autoboxing,Unboxing) ...

  6. 1.1、配置Python虚拟环境

    安装虚拟环境 系统:CentOS 7.2 python版本:Python 2.7.5 1.虚拟环境介绍 虚拟环境是Python解释器的一个私有副本,在这个环境中你可以安装私有包,而且不会影响系统中安装 ...

  7. 渗透实战(周三):Ettercap·ARP毒化&MITM中间人攻击

    今天,我们来讲解如何对小型Wi-Fi局域网发动网络攻击

  8. composer 安装教程

    https://getcomposer.org/download/ 邓士鹏 1.先检查php.ini是否开启ssl ;extension=php_openssl.dll   2. php -r &qu ...

  9. 【例题 4-5 uva 512】Spreadsheet Tracking

    [链接] 我是链接,点我呀:) [题意] 在这里输入题意 [题解] 每个操作对与一个点来说变化是固定的. 因此可以不用对整个数组进行操作. 对于每个询问,遍历所有的操作.对输入的(x,y)进行相应的变 ...

  10. Font Awesome使用方法

    Font Awesome(中文站点)是一套为Bootstrap而创造的图标字体库及CSS框架,在业界享有盛誉. FA包含了常规web开发所需要用到的几乎所有图标,并且免费授权使用,只需要下载即可.所有 ...