[工具类]泛型集合转换为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/
博客版权: 本文以学习、研究和分享为主,欢迎转载,但必须在文章页面明显位置给出原文连接。
如果文中有不妥或者错误的地方还望高手的你指出,以免误人子弟。如果觉得本文对你有所帮助不如【推荐】一下!如果你有更好的建议,不如留言一起讨论,共同进步!
再次感谢您耐心的读完本篇文章。http://www.cnblogs.com/wolf-sun/p/4593064.html

相关文章
|
JSON Java fastjson
简单实现_实体类与Json字符串互相转换
简单实现_实体类与Json字符串互相转换
125 1
|
Java
获取泛型map工具类
获取泛型map工具类
42 0
|
存储 C# 索引
C#泛型集合常用方法
C#泛型集合常用方法
76 0
jdbctemplate封装自定义对象,查询返回集合
jdbctemplate封装自定义对象,查询返回集合
316 0
|
设计模式 编译器 数据库
【机房重构】——DataTable和泛型集合
【机房重构】——DataTable和泛型集合
295 0
【机房重构】——DataTable和泛型集合
数组常用方法总结(部分方法利用了工具类)
数组常用方法总结(部分方法利用了工具类)
110 0

热门文章

最新文章