[工具类]泛型集合转换为DataTable
写在前面
在实际项目中,用到了将集合转换为DataTable,就试着封装了一个方法,记录一下。
代码
using System; using System.Collections.Generic; using System.Data; using System.Linq; using System.Reflection; using System.Text; using System.Threading.Tasks; namespace Wolfy.List2DataTable { class Program { static void Main(string[] args) { List<Person> lst = new List<Person>() { new Person(){ ID=1, Gender=false, Name="wolfy1"}, new Person(){ ID=2, Gender=false, Name="wolfy2"}, new Person(){ ID=3, Gender=false, Name="wolfy3"}, new Person(){ ID=4, Gender=false, Name="wolfy4"}, new Person(){ ID=5, Gender=false, Name="wolfy5"}, }; DataTable dt = List2DataTable<Person>(lst); Console.WriteLine("转换结束"); Console.Read(); } /// <summary> /// 将泛型集合转换为datatable /// </summary> /// <typeparam name="TEntity"></typeparam> /// <param name="entities"></param> /// <returns></returns> static DataTable List2DataTable<TEntity>(List<TEntity> entities) { if (entities == null) { throw new ArgumentNullException("转换的集合为空"); } Type type = typeof(TEntity); PropertyInfo[] properties = type.GetProperties(); DataTable dt = new DataTable(type.Name); foreach (var item in properties) { dt.Columns.Add(new DataColumn(item.Name) { DataType = item.PropertyType }); } foreach (var item in entities) { DataRow row = dt.NewRow(); foreach (var property in properties) { row[property.Name] = property.GetValue(item); } dt.Rows.Add(row); } return dt; } } public class Person { public int ID { set; get; } public string Name { set; get; } public bool Gender { set; get; } } }
测试结果:
-
博客地址:http://www.cnblogs.com/wolf-sun/
博客版权:如果文中有不妥或者错误的地方还望高手的你指出,以免误人子弟。如果觉得本文对你有所帮助不如【推荐】一下!如果你有更好的建议,不如留言一起讨论,共同进步! 再次感谢您耐心的读完本篇文章。
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· SQL Server 2025 AI相关能力初探
· AI编程工具终极对决:字节Trae VS Cursor,谁才是开发者新宠?
· 开源Multi-agent AI智能体框架aevatar.ai,欢迎大家贡献代码
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南