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. 机器学习:随机森林RF-OBB袋外错误率

    文章讲解比较详细,且有Python代码,可以作为有用的参考. 原文链接:http://blog.csdn.net/zhufenglonglove/article/details/51785220  参 ...

  2. react性能调谐与diff算法

    一个页面其实就相当于是一颗dom树,里面有很多它的子节点,然后你每次去操作一个事件,它都会生成一个虚拟dom,它会跟上一个虚拟dom进行比对,这里运用的算法叫做diff算法,当它找到需要改变的组件的时 ...

  3. 视频及MP3 播放浅析 Jplayer参数详细

    初识jplayer插件是因为它的兼容性是最好的,可以兼容到IE6,官网上对它兼容性有很详细的说明 这个是我选择使用它的首要原因. 现在从需求上来了解它的使用方法吧.第一个需求:MP3格式的音频在网页播 ...

  4. spring boot注解

    一.注解(annotations)列表 @SpringBootApplication:包含了@ComponentScan.@Configuration和@EnableAutoConfiguration ...

  5. eas之利用KDTableHelper批量填充数据

    // 下述代码将创建一个KDTable,并指定列名.表头单元格的显示值.和表体数据KDTable table = new KDTable();String [] columnKeys = new St ...

  6. CodeForces-999D Equalize the Remainders (贪心+神奇的STL)

    题意:给你一个n,m;其中n一定能被m整除,然后给你n个数 有一种操作   选择n个数中的任意一个,使其+1: 条件: Ci 属于[0,m-1]  Ci代表ai模m的余数为i的个数 且都等于n/m; ...

  7. [luogu4026 SHOI2008]循环的债务 (DP)

    传送门 吐槽洛谷难度标签qwq Solution 显然是一道神奇的DP,由于总钱数不变,我们只需要枚举前两个人的钱数就可知第三个人的钱数 DP的时候先枚举只用前k个币种,然后枚举前两个人的钱数,然后枚 ...

  8. python项目开发:ftp server开发

    程序要求: 1.用户加密认证 (对用户名密码进行MD5验证)2.允许同时多用户登陆 (使用socket server方法,为每个用户都创建一个信息文件)3.每个用户有自己的家目录,且只能访问自己的家目 ...

  9. 在Win32 Application 环境下实现MFC窗口的创建

    // Win32下MFC.cpp : Defines the entry point for the application.// #include "stdafx.h" clas ...

  10. 小记——Grub Rescue恢复

    下面我要讲的是一个悲伤的故事 引子 电脑状况简介:两块硬盘(1HHD.1SSD),SSD上装了LINUX(40G)+WIN10(50G)的双系统,SSD剩余部分在WIN下使用装程序,HHD做仓库.LI ...