度量快速开发平台-专业、快速的软件定制快开平台

 找回密码
 立即注册

QQ登录

只需一步,快速开始

搜索
热搜: 部件 流程 SQL
查看: 1778|回复: 3
打印 上一主题 下一主题

[分享] DataTable转成List集合

[复制链接]

542

主题

5916

帖子

1万

积分

作者

Rank: 7Rank: 7Rank: 7

积分
13589
跳转到指定楼层
楼主
发表于 2020-5-25 13:57:59 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
  1. public class ModelConvertHelper<T> where T : new()  // 此处一定要加上new()
  2.     {

  3.         public static IList<T> ConvertToModel(DataTable dt)
  4.         {

  5.             IList<T> ts = new List<T>();// 定义集合
  6.             Type type = typeof(T); // 获得此模型的类型
  7.             string tempName = "";
  8.             foreach (DataRow dr in dt.Rows)
  9.             {
  10.                 T t = new T();
  11.                 PropertyInfo[] propertys = t.GetType().GetProperties();// 获得此模型的公共属性
  12.                 foreach (PropertyInfo pi in propertys)
  13.                 {
  14.                     tempName = pi.Name;
  15.                     if (dt.Columns.Contains(tempName))
  16.                     {
  17.                         if (!pi.CanWrite) continue;
  18.                         object value = dr[tempName];
  19.                         if (value != DBNull.Value)
  20.                             pi.SetValue(t, value, null);
  21.                     }
  22.                 }
  23.                 ts.Add(t);
  24.             }
  25.             return ts;
  26.         }
  27.     }
复制代码

分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏
回复

使用道具 举报

542

主题

5916

帖子

1万

积分

作者

Rank: 7Rank: 7Rank: 7

积分
13589
沙发
 楼主| 发表于 2020-5-25 13:58:24 | 只看该作者
回复 支持 反对

使用道具 举报

542

主题

5916

帖子

1万

积分

作者

Rank: 7Rank: 7Rank: 7

积分
13589
板凳
 楼主| 发表于 2020-5-26 14:51:30 | 只看该作者
回复 支持 反对

使用道具 举报

235

主题

2547

帖子

5835

积分

论坛元老

Rank: 8Rank: 8

积分
5835
地板
发表于 2020-5-28 17:33:05 | 只看该作者
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

手机版|小黑屋|重庆度量科技  本站关键词:快速开发平台

GMT+8, 2024-11-28 07:51 , Processed in 0.122107 second(s), 25 queries .

Powered by Discuz! X3.2

© 2001-2013 Comsenz Inc.

快速回复 返回顶部 返回列表