using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Data;
using System.Reflection; namespace RftToModel {
class Program {
static void Main(string[] args) { var result = ToModel<TestModel>.GetDelegate_ToModelList(BuildSampleTable()); foreach (var item in result) {
Console.WriteLine(item);
} Console.Read(); } static DataTable BuildSampleTable() {
DataTable result = new DataTable();
result.Columns.Add("ID", typeof(int));
result.Columns.Add("Name", typeof(string));
result.Columns.Add("IsDeleted", typeof(bool)); result.Rows.Add(new object[] { 1, "M.K", false });
result.Rows.Add(new object[] { 2, "B.G", true }); return result; } } public class TestModel {
public int ID { get; set; }
public string Name { get; set; }
public bool IsDeleted { get; set; } public override string ToString() {
return string.Format("ID:{0} Name:{1} IsDeleted:{2}", ID, Name, IsDeleted);
}
} public delegate void SetValue<T>(T value); public static class ToModel<T> where T : class, new() { private static Delegate CreateSetDelegate(T model, string propertyName) {
MethodInfo mi = model.GetType().GetProperty(propertyName).GetSetMethod();
//这里构造泛型委托类型
Type delType = typeof(SetValue<>).MakeGenericType(GetPropertyType(propertyName)); return Delegate.CreateDelegate(delType, model, mi);
} private static Type GetPropertyType(string propertyName) {
return typeof(T).GetProperty(propertyName).PropertyType;
} public static IList<T> GetDelegate_ToModelList(DataTable dt) {
IList<T> list = new List<T>();
if (dt == null || dt.Rows.Count < 1) return list; Delegate setDelegate;
foreach (DataRow dr in dt.Rows) {
T model = new T();
foreach (DataColumn dc in dt.Columns) {
setDelegate = CreateSetDelegate(model, dc.ColumnName);
//这里改变类型
setDelegate.DynamicInvoke(Convert.ChangeType(dr[dc.ColumnName], GetPropertyType(dc.ColumnName)));
}
list.Add(model);
}
return list;
}
} }

  

最新文章

  1. DLL 生成与使用的全过程(2010-01-18 14:50:17)
  2. HDU 1253 胜利大逃亡
  3. 更改ubuntu下mysql的密码
  4. [嵌入式开发板]iTOP-4412以模块的方式编译驱动
  5. Windows上python开发--2安装django框架
  6. React Native 简介:用 JavaScript 搭建 iOS 应用 (1)
  7. TinyXml高速入口(一)
  8. servlet第2讲(上集)----创建servlet实例(实现servlet接口)
  9. JVM和java应用服务器调优
  10. ztree 获取根节点
  11. Web地图导图总结
  12. Python3 标准库学习
  13. 2018.06.27Firing(最大权闭合子图)
  14. python获取命令行参数的方法(汇总)
  15. python-day34--进程补充
  16. Django基础教程
  17. vue+webpack项目中使用dev-server搭建虚拟服务器,请求json文件数据,实现前后台分离开发
  18. WPF 添加OCX控件
  19. 从数据库反向生成django的models
  20. 轻量级HTTP服务器Nginx(配置与调试Nginx)

热门文章

  1. Tensorboard教程:Tensorflow命名空间与计算图可视化
  2. net-speeder
  3. IIS 网站日志分析
  4. C# 遍历枚举
  5. DELPHI中的快捷方式一览(完全版)
  6. 【CodeForces】889 C. Maximum Element 排列组合+动态规划
  7. placeholder样式设置
  8. 查询timestamp类型数据
  9. easyUI导出数据
  10. 计算1到N中各个数字出现的次数 --数位DP