C#使用泛型方法将Datatable转换成List对象集合
在项目中遇到需要将Datatable转换成对象的需求,通过dr[0]取下标这种获取,如果数据的顺序发生了改变则需要改变全部,工作量大
foreach (DataRow dr in dt.Rows)
{
CheckDetail info = new CheckDetail();
info.org_id = dr[0].ToString();
info.am_line_id = dr[1].ToString();
info.component = dr[2].ToString();
info.standard = dr[3].ToString();
info.frequency = dr[4].ToString();
info.status_code = dr[5].ToString();
info.status_name = dr[6].ToString();
info.activity_type = dr[7].ToString();
info.activity_type_name = dr[8].ToString();
info.check_results = dr[9].ToString();
info.remark = dr[10].ToString();
info.creation_date = FrameWork.ToDateTimeWithNull(dr[11].ToString());
info.created_by = dr[12].ToString();
info.last_updated_date = FrameWork.ToDateTimeWithNull(dr[13].ToString());
info.last_updated_by = dr[14].ToString();
info.am_head_id = dr[15].ToString();
info.check = dr[16].ToString();
info.Seq = Seq;
list.Add(info);
Seq++;
}
如果采用dr["columnName"]取列名的方式,一旦数据字段多了,工作量同样不小
foreach (DataRow dr in dt.Rows)
{
DeviceInfo info = new DeviceInfo();
info.Line_ID = dr["LINE_ID"].ToString();
info.Resource_ID = dr["RESOURCE_ID"].ToString();
info.Item_ID = dr["ITEM_ID"].ToString();
info.Item_Desc = dr["ITEM_DESC"].ToString();
info.Uom = dr["UOM"].ToString();
info.Desc = dr["DESCRIPTIONS"].ToString();
info.Avail_Qty = dr["AVAIL_QTY"].ToString();
info.Lot_Qty = dr["LOT_QTY"].ToString();
info.Flag = Convert.ToInt32(dr["FLAG"].ToString());
info.Plan_Flag = Convert.ToInt32(dr["PLAN_FLAG"].ToString());
info.Item_Code = dr["ITEM_CODE"].ToString();
info.Flag_Result = info.Flag == 1 ? true : false;
info.Plan_Flag_Result = info.Plan_Flag == 1 ? true : false;
list.Add(info);
}
所以才有了通过泛型+反射的这种方式 这种方式有个致命的缺点:对象属性的大小写一定要与DataTable中列名一致,不然无法获取到数据
/// <summary>
/// 将Datatable数据转换成实体对象集合
/// </summary>
/// <typeparam name="T">对象</typeparam>
/// <param name="dt">Datatable数据</param>
/// <returns></returns>
public List<T> ConvertDataTableToList<T>(DataTable dt) where T : new()
{
List<T> list = new List<T>(); foreach (DataRow row in dt.Rows)
{
T obj = new T(); foreach (DataColumn column in dt.Columns)
{
string columnName = column.ColumnName;
PropertyInfo property = typeof(T).GetProperty(columnName, BindingFlags.Public | BindingFlags.Instance); if (property != null && row[columnName] != DBNull.Value)
{
if (property.PropertyType == typeof(DateTime?))
{
DateTime? value = null;
string dateString = row[columnName].ToString();
DateTime parsedDate; if (DateTime.TryParse(dateString, out parsedDate))
{
value = parsedDate;
}
property.SetValue(obj, value);
}
else if (property.PropertyType == typeof(int?))
{
int? value = null;
string dateString = row[columnName].ToString();
int parsedDate; if (int.TryParse(dateString, out parsedDate))
{
value = parsedDate;
}
property.SetValue(obj, value);
}
else if (property.PropertyType == typeof(bool?))
{
bool? value = null;
string dateString = row[columnName].ToString();
bool parsedDate; if (bool.TryParse(dateString, out parsedDate))
{
value = parsedDate;
}
property.SetValue(obj, value);
}
else
{
object value = Convert.ChangeType(row[columnName], property.PropertyType);
property.SetValue(obj, value);
}
}
} list.Add(obj);
} return list;
}
下面是改良版本,这个版本可以直接用,不用担心对象属性大小写与DataTable列名不一致问题
public static List<T> ConvertDataTableToList<T>(DataTable dataTable) where T : new()
{
List<T> result = new List<T>(); if (dataTable == null || dataTable.Rows.Count == 0)
{
return result;
} foreach (DataRow row in dataTable.Rows)
{
T item = CreateItemFromRow<T>(row);
result.Add(item);
} return result;
} private static T CreateItemFromRow<T>(DataRow row) where T : new()
{
T item = new T();
PropertyInfo[] properties = typeof(T).GetProperties(); foreach (PropertyInfo property in properties)
{
string columnName = property.Name; if (!row.Table.Columns.Contains(columnName))
{
foreach (DataColumn column in row.Table.Columns)
{
if (string.Equals(column.ColumnName, columnName, StringComparison.OrdinalIgnoreCase))
{
columnName = column.ColumnName;
break;
}
}
} if (row.Table.Columns.Contains(columnName))
{
if (property.PropertyType == typeof(DateTime?))
{
DateTime? value = null;
string dateString = row[columnName].ToString();
DateTime parsedDate; if (DateTime.TryParse(dateString, out parsedDate))
{
value = parsedDate;
}
property.SetValue(item, value);
}
else if (property.PropertyType == typeof(int?))
{
int? value = null;
string dateString = row[columnName].ToString();
int parsedDate; if (int.TryParse(dateString, out parsedDate))
{
value = parsedDate;
}
property.SetValue(item, value);
}
else if (property.PropertyType == typeof(bool?))
{
bool? value = null;
string dateString = row[columnName].ToString();
bool parsedDate; if (bool.TryParse(dateString, out parsedDate))
{
value = parsedDate;
}
property.SetValue(item, value);
}
else
{
object value = Convert.ChangeType(row[columnName], property.PropertyType);
property.SetValue(item, value);
}
}
} return item;
}
C#使用泛型方法将Datatable转换成List对象集合的更多相关文章
- 简单的反射 把datatable 转换成list对象
/// <summary> /// 把datatable 转换成list对象 /// </summary> /// <typeparam name="T&quo ...
- DataTable 转换成 Json的3种方法
在web开发中,我们可能会有这样的需求,为了便于前台的JS的处理,我们需要将查询出的数据源格式比如:List<T>.DataTable转换为Json格式.特别在使用Extjs框架的时候,A ...
- DataTable转换成IList<T>的简单实现
DataTable的无奈 很多时候,我们需要去操作DataTable.但DataTable的操作,实在是太不方便了.Linq?lambda表达式?统统没有... 特别是对现有结果集做进一步筛选,这样的 ...
- asp.net dataTable转换成Json格式
/// <summary> /// dataTable转换成Json格式 /// </summary> /// <param name="dt"> ...
- 将DataTable转换成CSV文件
DataTable用于在.net项目中,用于缓存数据,DataTable表示内存中数据的一个表.CSV文件最早用在简单的数据库里,由于其格式简单,并具备很强的开放性,所以起初被扫图家用作自己图集的标记 ...
- 将DataSet(DataTable)转换成JSON格式(生成JS文件存储)
public static string CreateJsonParameters(DataTable dt) { /**/ /**/ /**/ /* /*********************** ...
- C#将DataTable转换成list的方法
本文实例讲述了C#将DataTable转换成list及数据分页的方法.分享给大家供大家参考.具体如下: /// <summary> /// 酒店评论列表-分页 /// </su ...
- DataTable转换成List<T>
很多时候需要将DataTable转换成一组model,直接对model执行操作会更加方便直观. 代码如下: public static class DataTableToModel { public ...
- 将list<对象>转换成DataTable,把DataTable转换成参数传入存储过程实现批量插入数据
领导让在存储过程中批量添加数据,找出效率最高的,我看到后台代码后,发现可以将list<对象>转换成DataTable,把DataTable转换成参数传入存储过程实现批量插入数据,知道还有其 ...
- C# DataTable 转换成JSON数据
原文:C# DataTable 转换成JSON数据 using System; using System.Collections.Generic; using System.Data; using S ...
随机推荐
- 3568F-麒麟KylinOS国产操作系统演示案例
- Linux的访问权限详解
题目 解读访问权限 rw-r--r--分别代表什么东西 r:代表可读 w:可写 e:可执行 方便起见进行拆分 rw- 代表文件所属用户的权限 r-- 代表同组用户的权限 r-- 代表其他用户的权限 同 ...
- Vue3 整理
前言 vue2基础篇链接:https://www.cnblogs.com/xiegongzi/p/15782921.html vue2组件化开发篇链接:https://www.cnblogs.com/ ...
- 【workerman】uniapp+thinkPHP5使用GatewayWorker实现实时通讯
前言 之前公司需要一个内部的通讯软件,就叫我做一个.通讯软件嘛,就离不开通讯了,然后我就想到了长连接.这里本人用的是GatewayWorker框架. 什么是GatewayWorker框架? Gatew ...
- Uipath学习(一)
Uipath 常用程序包总结: (1)正则表达式依赖程序包: System.Text.RegularExpressions 用法: 这个语句的作用是判断"溢达集团"这一串字符是否为 ...
- js - 面向对象--手稿
- yb课堂 首页home开发 《三十七》
Home模块开发 拆分子组件 Home banner videoList 指令属性里面取data里面的数据不用加{{}},html标签内容体中间则需要加双花括号 创建component文件夹 在src ...
- AOP模板
<?xml version="1.0" encoding="UTF-8"?> <beans xmlns="http://www.sp ...
- 机器学习策略篇:快速搭建你的第一个系统,并进行迭代(Build your first system quickly, then iterate)
快速搭建的第一个系统,并进行迭代 如果正在考虑建立一个新的语音识别系统,其实可以走很多方向,可以优先考虑很多事情. 比如,有一些特定的技术,可以让语音识别系统对嘈杂的背景更加健壮,嘈杂的背景可能是说咖 ...
- Zabbix 5.0 LTS URL 健康监测
更多细节详情看[zabbix官方文档] 需求 Zabbix 的URL健康监测功能允许你检测 Web 地址是否可用.正常工作以及响应速度.这对于监控网站的可用性和性能非常有用.例如,你可以监控公司网站. ...