c# DataTable 帮助类

public class DataTableHelper

{

#region DataTable转IList

/// <summary>

/// DataTable转IList集合

/// </summary>

/// <typeparam name="T"></typeparam>

/// <param name="dataTable"></param>

/// <returns></returns>

public static IList<T> ToList<T>(DataTable dataTable) where T : class, new()

{

IList<T> list = new List<T>();// 定义集合

if (dataTable != null)

{

foreach (DataRow dr in dataTable.Rows)

{

T t = new T();

PropertyInfo[] propertys = t.GetType().GetProperties();// 获得此模型的公共属性

foreach (PropertyInfo pi in propertys)

{

var name = pi.Name;

if (dataTable.Columns.Contains(name))

{

if (!pi.CanWrite) continue;

object value = dr[name];

if (value != DBNull.Value)

{

pi.SetValue(t, value, null);

}

}

}

list.Add(t);

}

}

return list;

}

#endregion

}

相关推荐
在下雨599几秒前
项目讲解1
开发语言·数据结构·c++·算法·单例模式
再努力"亿"点点3 分钟前
Sklearn(机器学习)实战:鸢尾花数据集处理技巧
开发语言·python
饭碗的彼岸one25 分钟前
C++ 并发编程:异步任务
c语言·开发语言·c++·后端·c·异步
OxYGC1 小时前
[玩转GoLang] 5分钟整合Gin / Gorm框架入门
开发语言·golang·gin
锐策1 小时前
Lua 核心知识点详解
开发语言·lua
水饺编程1 小时前
Windows 命令行:cd 命令3,当前目录,父目录,根目录
c语言·c++·windows·visual studio
kyle~1 小时前
C/C++---动态内存管理(new delete)
c语言·开发语言·c++
落日沉溺于海2 小时前
React From表单使用Formik和yup进行校验
开发语言·前端·javascript
疯狂的维修2 小时前
C#中一段程序类比博图
c#
鲸屿1953 小时前
python之socket网络编程
开发语言·网络·python