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 ...
随机推荐
- 合并STM32 iap的hex文件合并为一个hex文件
--- title: 合并STM32 iap的hex文件合并为一个hex文件 date: 2020-06-15 04:32:26 categories: tags: - iap - stm32 --- ...
- 【仿真】Carla之Docker 运行 及 渲染相关 [6]
参考与前言 carla官方对于docker 运行的描述: CARLA in Docker Docker的使用:[暂时没贴] 相关已知issue,欢迎补充 https://github.com/carl ...
- 【规范】Git分支管理,看看我司是咋整的
前言 缘由 Git分支管理好,走到哪里都是宝 事情起因: 最近翻看博客中小伙伴评论时,发现文章[规范]看看人家Git提交描述,那叫一个规矩一条回复: 本狗亲测在我司中使用规范的好处,遂把我司的Git分 ...
- Bom浏览器对象模型 -- 手稿
------------恢复内容开始------------ ------------恢复内容结束------------ ------------恢复内容开始------------ ------- ...
- Java FastJson解析json字符串
json转map Map<String, 实体类> titleMap=JSON.parseObject(JSON字符串, new TypeReference<HashMap<S ...
- MyBatis-Plus 整理
# 前言 代码生成器插件选择去这里:https://www.cnblogs.com/zixq/p/16726534.html 相关插件在那里面已经提到了 # 上手 MyBatis-Plus 是一个 M ...
- IDEA之调试或运行的小助手日志插件Grep Console:不同颜色区分,查看日志看方便【工欲善其事必先利其器】
简介 Grep Console是一款方便开发者对idea控制台输出日志进行个性化管理的插件.这个插件还是很用的,在满屏的日志中,迅速找到自己关注的内容,调试程序的绝佳工具. 功能特性 Grep Con ...
- AT_abc218_d 题解
洛谷链接&Atcoder 本篇题解为此题较简单做法及较少码量,并且码风优良,请放心阅读. 题目简述 给定一个平面内的 \(N\) 个点的坐标,求这 \(N\) 个点中选 \(4\) 个点可构成 ...
- java小技巧~修改对象的属性名
今天联调的时候,有个功能是在初始化的时候将图片路径回显到vant组件的上传组件上,但是vant组件需要图片路径名叫url,而后端返给我的路径名叫filePath,而且是双层嵌套.一个个遍历老麻烦了,下 ...
- ELK多租户方案
一.前言 日志分析是目前重要的系统调试和问题排查的重要手段之一,而目前分布式系统由于实例和机器众多,所以构建一套统一日志系统是非常必要的:ELK提供了一整套解决方案,并且都是开源软件,之间互相配合使用 ...