using System;
using System.Collections.Generic;
using System.Data;
using System.Linq;
using System.Reflection;
using System.Collections;
namespace XHSoft.LicenseManagerUI
{
/// <summary>
/// 扩展属性
/// </summary>
public static class Extensions
{
#region 数据集转换泛型集合扩展
/// <summary>
/// DataSet转换为泛型集合
/// </summary>
/// <typeparam name="T">泛型类型</typeparam>
/// <param name="ds">DataSet数据集</param>
/// <param name="tableIndex">待转换数据表索引,默认第0张表</param>
/// <returns>返回泛型集合</returns>
public static IList<T> ToList<T>(this DataSet ds, int tableIndex = 0)
{
if (ds == null || ds.Tables.Count < 0) return null;
if (tableIndex > ds.Tables.Count - 1)
return null;
if (tableIndex < 0)
tableIndex = 0;
DataTable dt = ds.Tables[tableIndex];
// 返回值初始化
IList<T> result = new List<T>();
for (int j = 0; j < dt.Rows.Count; j++)
{
T _t = (T)Activator.CreateInstance(typeof(T));
PropertyInfo[] propertys = _t.GetType().GetProperties();
foreach (PropertyInfo pi in propertys)
{
for (int i = 0; i < dt.Columns.Count; i++)
{
// 属性与字段名称一致的进行赋值
if (pi.Name.Equals(dt.Columns[i].ColumnName))
{
// 数据库NULL值单独处理
if (dt.Rows[j][i] != DBNull.Value)
pi.SetValue(_t, dt.Rows[j][i], null);
else
pi.SetValue(_t, null, null);
break;
}
}
}
result.Add(_t);
}
return result;
}
/// <summary>
/// DataTable转换为泛型集合
/// </summary>
/// <typeparam name="T">泛型类型</typeparam>
/// <param name="dt">DataTable数据表</param>
/// <returns>返回泛型集合</returns>
public static IList<T> ToList<T>(this DataTable dt) where T:class,new()
{
if (dt == null || dt.Rows.Count <= 0) return null;
List<T> list =new List<T>();
#region 方法一:
//T model;
//Type infos = typeof(T);
////object tempValue;
//foreach (DataRow dr in dt.Rows)
//{
// model = new T();
// 1.
// infos.GetProperties().ToList().ForEach(p =>p.SetValue(model, dr[p.Name], null));
// 2.
// //infos.GetProperties().ToList().ForEach(p =>
// //{
// // tempValue = dr[p.Name];
// // if (!string.IsNullOrEmpty(tempValue.ToString()))
// // p.SetValue(model, tempValue, null);
// //});
// list.Add(model);
//}
#endregion
#region 方法二: 比方法一快
PropertyInfo[] propertys = typeof(T).GetProperties();
for (int j = 0; j < dt.Rows.Count; j++)
{
T _t = (T)Activator.CreateInstance(typeof(T));
foreach (PropertyInfo pi in propertys)
{
// 属性与字段名称一致的进行赋值
if (pi.Name.Equals(dt.Columns[pi.Name].ColumnName))
{
if (dt.Rows[j][pi.Name] != DBNull.Value)
pi.SetValue(_t, dt.Rows[j][pi.Name], null);
else
pi.SetValue(_t, null, null);
}
}
list.Add(_t);
}
#endregion
return list;
}
/// <summary>
/// DataSet转换为泛型集合
/// </summary>
/// <typeparam name="T">泛型类型</typeparam>
/// <param name="ds">DataSet数据集</param>
/// <param name="tableName">待转换数据表名称,名称为空时默认第0张表</param>
/// <returns>返回泛型集合</returns>
public static IList<T> ToList<T>(this DataSet ds, string tableName)
{
int _TableIndex = 0;
if (ds == null || ds.Tables.Count < 0)
return null;
if (string.IsNullOrEmpty(tableName))
return ToList<T>(ds, 0);
for (int i = 0; i < ds.Tables.Count; i++)
{
// 获取Table名称在Tables集合中的索引值
if (ds.Tables[i].TableName.Equals(tableName))
{
_TableIndex = i;
break;
}
}
return ToList<T>(ds, _TableIndex);
}
#endregion
#region 泛型集合转换为数据集扩展
/// <summary>
/// 将泛型集合转换成DataSet数据集
/// </summary>
/// <typeparam name="T">T类型</typeparam>
/// <param name="list">泛型集合</param>
/// <returns>DataSet数据集</returns>
public static DataSet ToDataSet<T>(this IList<T> list)
{
Type elementType = typeof(T);
var ds = new DataSet();
var t = new DataTable();
ds.Tables.Add(t);
elementType.GetProperties().ToList().ForEach(propInfo => t.Columns.Add(propInfo.Name, Nullable.GetUnderlyingType(propInfo.PropertyType) ?? propInfo.PropertyType));
foreach (T item in list)
{
var row = t.NewRow();
elementType.GetProperties().ToList().ForEach(propInfo => row[propInfo.Name] = propInfo.GetValue(item, null) ?? DBNull.Value);
t.Rows.Add(row);
}
return ds;
}
/// <summary>
/// 泛型集合转换成DataTable表
/// </summary>
/// <typeparam name="T">T类型</typeparam>
/// <param name="list">泛型集合</param>
/// <returns>DataTable表</returns>
public static DataTable ToDataTable<T>(this IList<T> list)
{
return ToDataTable(list, null);
}
/// <summary>
/// 泛型集合转换成DataTable表
/// </summary>
/// <typeparam name="T">T类型</typeparam>
/// <param name="list">泛型集合</param>
/// <param name="_tableName">Table名称</param>
/// <returns>DataTable表</returns>
public static DataTable ToDataTable<T>(this IList<T> list, string _tableName)
{
Type elementType = typeof(T);
var dt = new DataTable();
if (_tableName == "null")
dt.TableName = _tableName;
elementType.GetProperties().ToList().ForEach(propInfo => dt.Columns.Add(propInfo.Name, Nullable.GetUnderlyingType(propInfo.PropertyType) ?? propInfo.PropertyType));
foreach (T item in list)
{
var row = dt.NewRow();
elementType.GetProperties().ToList().ForEach(propInfo => row[propInfo.Name] = propInfo.GetValue(item, null) ?? DBNull.Value);
dt.Rows.Add(row);
}
return dt;
}
#endregion
#region 以下为IEnumerable扩展实现
/// <summary>
/// 给非强类型的IEnumerable返回头一个元素。
/// </summary>
public static object First(this IEnumerable col)
{
foreach (var item in col)
return item;
throw new IndexOutOfRangeException();
}
/// <summary>
/// 给非强类型的IEnumerable返回头一个强类型的元素
/// </summary>
public static object First<T>(this IEnumerable col)
{
return (T)col.First();
}
/// <summary>
/// 基本上和List<T>的ForEach方法一致。
/// </summary>
public static void Each<T>(this IEnumerable<T> col, Action<T> handler)
{
foreach (var item in col)
handler(item);
}
/// <summary>
/// 带索引的遍历方法。
/// </summary>
public static void Each<T>(this IEnumerable<T> col, Action<T, int> handler)
{
int index = 0;
foreach (var item in col)
handler(item, index++);
}
/// <summary>
/// 可以半途中断执行的遍历方法。
/// </summary>
public static void Each<T>(this IEnumerable<T> col, Func<T, bool> handler)
{
foreach (var item in col)
if (!handler(item)) break;
}
/// <summary>
/// 可以半途中段的带索引的遍历方法。
/// </summary>
public static void Each<T>(this IEnumerable<T> col, Func<T, int, bool> handler)
{
int index = 0;
foreach (var item in col)
if (!handler(item, index++)) break;
}
#endregion
#region 以下为IEnumerable<T>的非泛型实现
public static void Each<T>(this IEnumerable col, Action<object> handler)
{
foreach (var item in col)
handler(item);
}
public static void Each<T>(this IEnumerable col, Action<object, int> handler)
{
int index = 0;
foreach (var item in col)
handler(item, index++);
}
public static void Each<T>(this IEnumerable col, Func<object, bool> handler)
{
foreach (var item in col)
if (!handler(item)) break;
}
public static void Each<T>(this IEnumerable col, Func<object, int, bool> handler)
{
int index = 0;
foreach (var item in col)
if (!handler(item, index++)) break;
}
#endregion
}
}

C# DataTable,DataSet,IList,IEnumerable 互转扩展属性的更多相关文章

  1. C#高效导出Excel(IList转DataTable,DataSet)

    微软的Excel操作类导出Excel会很慢,此方法简单的把表中内容以字符串的形式写入到Excel中,用到的一个技巧就是"\t". C#中的\t相当于Tab键,写入到Excel中时就 ...

  2. DataTable,List,Dictonary互转,筛选及相关写法

    1.创建自定义DataTable  /// 创建自定义DataTable(一) 根据列名字符串数组, /// </summary> /// <param name="sLi ...

  3. DataTable 和Json 字符串互转

    #region DataTable 转换为Json字符串实例方法 /// <summary> /// GetClassTypeJosn 的摘要说明 /// </summary> ...

  4. DateTable与List<T>相互转换 及JSON与DataTable(DataSet)相互转化

    http://www.360doc.com/content/13/0712/09/10504424_299336674.shtml Linq处理List数据 http://blog.163.com/l ...

  5. Newtonsoft.Json高级用法DataContractJsonSerializer,JavaScriptSerializer 和 Json.NET即Newtonsoft.Json datatable,dataset,modle,序列化

    原文地址:https://www.cnblogs.com/yanweidie/p/4605212.html Newtonsoft.Json介绍 在做开发的时候,很多数据交换都是以json格式传输的.而 ...

  6. Newtonsoft.Json高级用法,json序列号,model反序列化,支持序列化和反序列化DataTable,DataSet,Entity Framework和Entity,字符串

    原文地址:https://www.cnblogs.com/yanweidie/p/4605212.html 手机端应用讲究速度快,体验好.刚好手头上的一个项目服务端接口有性能问题,需要进行优化.在接口 ...

  7. 完整DataTable与IList互换(转)

    public class CollectionHelper { private CollectionHelper() { } public static DataTable ConvertTo< ...

  8. IEnumerable接口的扩展方法

    /// <summary>/// IEnumerable接口的扩展方法,支持它的实现类是List的情况/// </summary>using System.Collection ...

  9. DataTable和List集合互转

    /// <summary> /// 将集合转换成DataTable /// </summary> /// <param name="list"> ...

随机推荐

  1. 从Cell类型转变成数据型

    我们有一个如下的cell数据 cdata = {'1' '11' '111' '1111' '11111'}; 现在要把他转变成double型的数组,很自然会想到的方法是cell2mat,可悲的是会遇 ...

  2. Android必知必会-带列表的地图POI周边搜索

    如果移动端访问不佳,请尝试–> Github版 2016-08-22 更新 注意:在 Activity 代码中的onPoiSearched(PoiResult result, int rCode ...

  3. LATEX TEMPLATE (SPRINGER) (*.BST)

    该模板在哪里下载? http://www.springer.com/computer/image+processing/journal/11263, Instructions for Authors, ...

  4. 1.3、Android Studio创建一个Android Library

    一个Android Library结构上与Android app模块相同.它可以包含构建一个app需要的所有东西,包括圆满,资源文件和AndroidManifest.xml.然而,并非编译成运行在设备 ...

  5. (NO.00005)iOS实现炸弹人游戏(十一):怪物之火精灵

    大熊猫猪·侯佩原创或翻译作品.欢迎转载,转载请注明出处. 如果觉得写的不好请多提意见,如果觉得不错请多多支持点赞.谢谢! hopy ;) 从本篇开始我们一次介绍一下游戏中敌人的制作过程.看过第一篇的小 ...

  6. Android开发学习之路--MAC下Android Studio开发环境搭建

    自从毕业开始到现在还没有系统地学习android应用的开发,之前一直都是做些底层的驱动,以及linux上的c开发.虽然写过几个简单的app,也对android4.0.3的源代码做过部分的分析,也算入门 ...

  7. UNIX网络编程——I/O复用:select和poll函数

    我们看到TCP客户同时处理两个输入:标准输入和TCP套接字.我们遇到的问题是就在客户阻塞于(标准输入上)fgets调用,服务器进程会被杀死.服务器TCP虽然正确的给客户TCP发送了一个FIN,但是既然 ...

  8. 从websphere6.1迁移到weblogic10.3的问题总结

     系统采用war包的方式部署. 问题一: ####<2011-3-29 下午05时17分43秒 CST> <Info> <ServletContext-/MIS-be ...

  9. 用过的一些Android设备调试特性注意点(挖坑帖)

    华为3C Activity切换动画偏快. 显示大图时不容易出现OOM(应用最大内容要比其他手机大一点),所以调试OOM问题时不要用此手机,否则难以发现问题. 小米3 不要调用系统的裁图功能.因为返回的 ...

  10. JAVA内部类_2

    (d)匿名内部类 如果只创建这个类的第一个对象,就无需命名. 由于构造器的名字必须与类名相同,而匿名类没有类名,所以匿名类没有构造器. 取而代之的是将构造器参数传递给超类构造器. 在内部类实现接口的时 ...