• linkedu视频
  • 平面设计
  • 电脑入门
  • 操作系统
  • 办公应用
  • 电脑硬件
  • 动画设计
  • 3D设计
  • 网页设计
  • CAD设计
  • 影音处理
  • 数据库
  • 程序设计
  • 认证考试
  • 信息管理
  • 信息安全
菜单
linkedu.com
  • 网页制作
  • 数据库
  • 程序设计
  • 操作系统
  • CMS教程
  • 游戏攻略
  • 脚本语言
  • 平面设计
  • 软件教程
  • 网络安全
  • 电脑知识
  • 服务器
  • 视频教程
  • JavaScript
  • ASP.NET
  • PHP
  • 正则表达式
  • AJAX
  • JSP
  • ASP
  • Flex
  • XML
  • 编程技巧
  • Android
  • swift
  • C#教程
  • vb
  • vb.net
  • C语言
  • Java
  • Delphi
  • 易语言
  • vc/mfc
  • 嵌入式开发
  • 游戏开发
  • ios
  • 编程问答
  • 汇编语言
  • 微信小程序
  • 数据结构
  • OpenGL
  • 架构设计
  • qt
  • 微信公众号
您的位置:首页 > 程序设计 >ASP.NET > C#将DataTable转化为List<T>

C#将DataTable转化为List<T>

作者: 字体:[增加 减小] 来源:互联网 时间:2017-05-11

通过本文主要向大家介绍了马桶c的个人空间,马桶c,c站,欲情 c max,c语言等相关知识,希望对您有所帮助,也希望大家支持linkedu.com www.linkedu.com

在使用三层架构开发一个网站时,希望把DataTable对象转换为List<T>对象,于是在网上找资料,总结一个比较方便的方法来实现——使用反射。

思路:

初始化一个List<T>对象 获取到T所有的属性,初始化一个T对象 遍历所有属性,如果DataTable中含有相应属性的值则为T对象赋值,如果没有对应的列则检查数据模型是否定义有误(属性名与列名比较时不区分大小写) 将T对象添加到List<T>对象中

  总体代码:

反射获取到的属性信息

DataTable中的列信息,对比上图,我们会发现,属性中首字母都是大写,而列名则是采用的Camel命名,首字母是小写,但是通过单步调试可以发现 dt.Columns.Contanis(tempName) 的返回值为true,由此可以证明,这样比较时是不区分大小写的

获取到T对象信息

/// <summary> 
    /// 利用反射将DataTable转换为List<T>对象
    /// </summary> 
    /// <param name="dt">DataTable 对象</param> 
    /// <returns>List<T>集合</returns> 
    public static List<T> DataTableToList<T>(DataTable dt) where T :class,new ()
    { 
      // 定义集合 
      List<T> ts = new List<T>(); 
      //定义一个临时变量 
      string tempName = string.Empty; 
      //遍历DataTable中所有的数据行 
      foreach (DataRow dr in dt.Rows) 
      { 
        T t = new T(); 
        // 获得此模型的公共属性 
        PropertyInfo[] propertys = t.GetType().GetProperties(); 
        //遍历该对象的所有属性 
        foreach (PropertyInfo pi in propertys) 
        { 
          tempName = pi.Name;//将属性名称赋值给临时变量 
          //检查DataTable是否包含此列(列名==对象的属性名)  
          if (dt.Columns.Contains(tempName)) 
          { 
            //取值 
            object value = dr[tempName];
             //如果非空,则赋给对象的属性 
             if (value != DBNull.Value)
             {
               pi.SetValue(t,value,null); 
             }  
          } 
        } 
        //对象添加到泛型集合中 
        ts.Add(t); 
      } 
      return ts; 
    }
</div>

</div>
分享到:QQ空间新浪微博腾讯微博微信百度贴吧QQ好友复制网址打印

您可能想查找下面的文章:

  • C#开发微信 二维码鼠标滑动 图像显示隐藏效果(推荐)
  • C#开发微信 二维码鼠标滑动 图像显示隐藏效果(推荐)
  • C#.net 微信公众账号接口开发
  • C#实现把图片下载到服务器代码
  • C#将DataTable转化为List<T>
  • C#中OpenFileDialog和PictrueBox的用法分析
  • c#网站WebConfig中域名引用示例介绍
  • C#中的switch case使用介绍
  • C#随机生成不重复字符串的两个不错方法
  • C# 判断两张图片是否一致的快速方法

相关文章

  • 2017-05-11mvc上传到美橙云虚拟机系列问题的解决方法
  • 2017-05-11asp.net中url字符串编码乱码的原因与解决方法
  • 2017-05-11asp.net membership 密码重设
  • 2018-08-20详解.Net core2.0日志组件Log4net、Nlog简单性能测试
  • 2017-05-11C# 给站点指定位置的某种格式的图片添加水印
  • 2017-05-11asp.net性能优化之使用Redis缓存(入门)
  • 2017-05-11asp.net下实现支持文件分块多点异步上传的 Web Services
  • 2017-05-11aspnet_regiis.exe命令使用方法
  • 2017-05-11无法将类型为“System.Web.UI.WebControls.HiddenField”的对象强制转换为类型的错误的解决
  • 2017-05-11使用Entity Framework(4.3.1版本)遇到的问题整理

文章分类

  • JavaScript
  • ASP.NET
  • PHP
  • 正则表达式
  • AJAX
  • JSP
  • ASP
  • Flex
  • XML
  • 编程技巧
  • Android
  • swift
  • C#教程
  • vb
  • vb.net
  • C语言
  • Java
  • Delphi
  • 易语言
  • vc/mfc
  • 嵌入式开发
  • 游戏开发
  • ios
  • 编程问答
  • 汇编语言
  • 微信小程序
  • 数据结构
  • OpenGL
  • 架构设计
  • qt
  • 微信公众号

最近更新的内容

    • ABP框架的基础配置及依赖注入讲解
    • asp.net显示图片到指定的Image控件中 具体实现
    • asp.net中显示1至20相同数字相乘的结果,若值比50小就不显示
    • 加密web.config的方法分享
    • ASP.NET MVC中异常Exception拦截的深入理解
    • asp.net中使用自定义控件的方式实现一个分页控件的代码
    • asp.net Split分割字符串的方法
    • .NET下实现数字和字符相混合的验证码实例
    • .net生成缩略图及水印图片时出现GDI+中发生一般性错误解决方法
    • asp.net 在DNN模块开发中遇到的resx怪问题

关于我们 - 联系我们 - 免责声明 - 网站地图

©2020-2025 All Rights Reserved. linkedu.com 版权所有