1. public static class DataTableExtensions
  2. {
  3. /// <summary>
  4. /// 转化一个DataTable
  5. /// </summary>
  6. /// <typeparam name="T"></typeparam>
  7. /// <param name="list"></param>
  8. /// <returns></returns>
  9. public static DataTable ToDataTable<T>(this IEnumerable<T> list)
  10. {
  11. //创建属性的集合
  12. List<PropertyInfo> pList = new List<PropertyInfo>();
  13. //获得反射的入口
  14. Type type = typeof(T);
  15. DataTable dt = new DataTable();
  16. //把所有的public属性加入到集合 并添加DataTable的列
  17. Array.ForEach<PropertyInfo>(type.GetProperties(), p => { pList.Add(p); dt.Columns.Add(p.Name, p.PropertyType); });
  18. foreach (var item in list)
  19. {
  20. //创建一个DataRow实例
  21. DataRow row = dt.NewRow();
  22. //给row 赋值
  23. pList.ForEach(p => row[p.Name] = p.GetValue(item, null));
  24. //加入到DataTable
  25. dt.Rows.Add(row);
  26. }
  27. return dt;
  28. }
  29. /// <summary>
  30. /// DataTable 转换为List 集合
  31. /// </summary>
  32. /// <typeparam name="TResult">类型</typeparam>
  33. /// <param name="dt">DataTable</param>
  34. /// <returns></returns>
  35. public static List<T> ToList<T>(this DataTable dt) where T : class, new()
  36. {
  37. //创建一个属性的列表
  38. List<PropertyInfo> prlist = new List<PropertyInfo>();
  39. //获取TResult的类型实例  反射的入口
  40. Type t = typeof(T);
  41. //获得TResult 的所有的Public 属性 并找出TResult属性和DataTable的列名称相同的属性(PropertyInfo) 并加入到属性列表
  42. Array.ForEach<PropertyInfo>(t.GetProperties(), p => { if (dt.Columns.IndexOf(p.Name) != -1) prlist.Add(p); });
  43. //创建返回的集合
  44. List<T> oblist = new List<T>();
  45. foreach (DataRow row in dt.Rows)
  46. {
  47. //创建TResult的实例
  48. T ob = new T();
  49. //找到对应的数据  并赋值
  50. prlist.ForEach(p => { if (row[p.Name] != DBNull.Value) p.SetValue(ob, row[p.Name], null); });
  51. //放入到返回的集合中.
  52. oblist.Add(ob);
  53. }
  54. return oblist;
  55. }
  56. /// <summary>
  57. /// 将集合类转换成DataTable
  58. /// </summary>
  59. /// <param name="list">集合</param>
  60. /// <returns></returns>
  61. public static DataTable ToDataTableTow(IList list)
  62. {
  63. DataTable result = new DataTable();
  64. if (list.Count > 0)
  65. {
  66. PropertyInfo[] propertys = list[0].GetType().GetProperties();
  67. foreach (PropertyInfo pi in propertys)
  68. {
  69. result.Columns.Add(pi.Name, pi.PropertyType);
  70. }
  71. for (int i = 0; i < list.Count; i++)
  72. {
  73. ArrayList tempList = new ArrayList();
  74. foreach (PropertyInfo pi in propertys)
  75. {
  76. object obj = pi.GetValue(list[i], null);
  77. tempList.Add(obj);
  78. }
  79. object[] array = tempList.ToArray();
  80. result.LoadDataRow(array, true);
  81. }
  82. }
  83. return result;
  84. }
  85. /**/
  86. /// <summary>
  87. /// 将泛型集合类转换成DataTable
  88. /// </summary>
  89. /// <typeparam name="T">集合项类型</typeparam>
  90. /// <param name="list">集合</param>
  91. /// <returns>数据集(表)</returns>
  92. public static DataTable ToDataTable<T>(IList<T> list)
  93. {
  94. return ToDataTable<T>(list, null);
  95. }
  96. /**/
  97. /// <summary>
  98. /// 将泛型集合类转换成DataTable
  99. /// </summary>
  100. /// <typeparam name="T">集合项类型</typeparam>
  101. /// <param name="list">集合</param>
  102. /// <param name="propertyName">需要返回的列的列名</param>
  103. /// <returns>数据集(表)</returns>
  104. public static DataTable ToDataTable<T>(IList<T> list, params string[] propertyName)
  105. {
  106. List<string> propertyNameList = new List<string>();
  107. if (propertyName != null)
  108. propertyNameList.AddRange(propertyName);
  109. DataTable result = new DataTable();
  110. if (list.Count > 0)
  111. {
  112. PropertyInfo[] propertys = list[0].GetType().GetProperties();
  113. foreach (PropertyInfo pi in propertys)
  114. {
  115. if (propertyNameList.Count == 0)
  116. {
  117. result.Columns.Add(pi.Name, pi.PropertyType);
  118. }
  119. else
  120. {
  121. if (propertyNameList.Contains(pi.Name))
  122. result.Columns.Add(pi.Name, pi.PropertyType);
  123. }
  124. }
  125. for (int i = 0; i < list.Count; i++)
  126. {
  127. ArrayList tempList = new ArrayList();
  128. foreach (PropertyInfo pi in propertys)
  129. {
  130. if (propertyNameList.Count == 0)
  131. {
  132. object obj = pi.GetValue(list[i], null);
  133. tempList.Add(obj);
  134. }
  135. else
  136. {
  137. if (propertyNameList.Contains(pi.Name))
  138. {
  139. object obj = pi.GetValue(list[i], null);
  140. tempList.Add(obj);
  141. }
  142. }
  143. }
  144. object[] array = tempList.ToArray();
  145. result.LoadDataRow(array, true);
  146. }
  147. }
  148. return result;
  149. }
  150. }

LIst和table的转换的更多相关文章

  1. 如何将jsp页面的table报表转换到excel报表导出

    假设这就是你的jsp页面: 我们会添加一个“导出到excel”的超链接,它会把页面内容导出到excel文件中.那么这个页面会变成这个样子 在此,强调一下搜索时关键词的重要性,这样一下子可以定位到文章, ...

  2. sp 数据拼接html table表转换xml,发邮件

    USE [BES_ADV] GO /****** Object: StoredProcedure [dbo].[RSP_FN_UNAPPLIED_Mail_Reminder] Script Date: ...

  3. Bootstrap Table的例子(转载)

    转载自:http://wenzhixin.net.cn/p/bootstrap-table/docs/examples.html#classes-table 使用的API: data1.json da ...

  4. Oracle数据库中日期/数字和字符之间的转换和计算

    --查出当前系统时间 select SYSDATE from table; --格式转换 -- TO_CHAR 把日期或数字转换为字符串 -- TO_CHAR(number, '格式') -- TO_ ...

  5. 【翻译】Flink Table Api & SQL —Streaming 概念 ——时间属性

    本文翻译自官网: Time Attributes   https://ci.apache.org/projects/flink/flink-docs-release-1.9/dev/table/str ...

  6. python运算符

    aaarticlea/png;base64,iVBORw0KGgoAAAANSUhEUgAAAcIAAAHCCAIAAADzel4SAAAgAElEQVR4Aey9+bMcSXLnV1dmna/ejR

  7. 利用Servlet导出Excel

    -----因为Excel可以打开HTML文件,因此可以利用页面的Form表单把页面中的table内容提交给Servlet,然后后台把提交上来的table内容转换成文件流的形式,并以下载的形式转给客户端 ...

  8. 数据库多表连接方式介绍-HASH-JOIN

    1.概述 hash join是一种数据库在进行多表连接时的处理算法,对于多表连接还有两种比较常用的方式:sort merge-join 和 nested loop. 为了比较清楚的介绍hash joi ...

  9. 在SQL中使用CLR提供基本函数对二进制数据进行解析与构造

      二进制数据包的解析一般是借助C#等语言,在通讯程序中解析后形成字段,再统一单笔或者批量(表类型参数)提交至数据库,在通讯程序中,存在BINARY到struct再到table的转换. 现借助CLR提 ...

随机推荐

  1. POI2011题解

    POI2011题解 2214先咕一会... [BZOJ2212][POI2011]Tree Rotations 线段树合并模板题. #include<cstdio> #include< ...

  2. USB相关的sysfs文件

    主要来自driver/usb/core/sysfs.c: 1.bConfigurationValue RW,W时调用了usb_set_configuration()实时设置配置.根据USB规范(例如第 ...

  3. 定时器Timer&ScheduledThreadPoolExecutor

    定时器Timer&ScheduledThreadPoolExecutor /** * @ClassName: TimerTest * @author: daniel.zhao * @date: ...

  4. prefix sums--codility

    lesson 5: prefix sums 1. PassingCars 2. CountDiv 3. GenomicRangeQuery 4. MinAvgTwoSlice lesson 5: pr ...

  5. 【c#】设置Socket连接、接收超时(转)

    用到Socket,发现如果连接错误,比如Connect的端口不对,会造成很长时间的延时,程序就僵在那里,效果很不好: 在网上找到很方便的设置办法,分享如下: Socket.SetSocketOptio ...

  6. 阿里云OSS linux使用备忘录

    ossutil config example: accessKeyId = "AccessKeyId"; accessKeySecret = "AccessKeySecr ...

  7. opensuse下配置IP、DNS、GATEWAY

    本人物理主机IP描述 IPv4 地址 . . . . . . . . . . . . : 192.168.1.101(首选)子网掩码  . . . . . . . . . . . . : 255.25 ...

  8. 在Windows Server 2012启用或关闭Internet Explorer增强的安全配置

    在 Windows Sever 2012 中打开 IE 浏览器时,IE10 会出现[已启用 Internet Explorer 增强的安全配置]的提示信息. 在安全性等级中会设置以[高安全性],如果我 ...

  9. 关于 android百度地图 调用 地理位置 经纬度坐标,只调用一次的解决方法,通知栏不总是 搜索 GPS 。。。

    上代码吧... //读取当前坐标 final LocationClient mLocationClient = new LocationClient(mActivity); mLocationClie ...

  10. 关于Class.getResource和ClassLoader.getResource的路径问题(转)

    参考博客:http://www.cnblogs.com/yejg1212/p/3270152.html Class.getResource(String path) 当path以/开头,如/a/b/c ...