zoukankan      html  css  js  c++  java
  • .NET C# 泛型集合转DataTable

    1.功能类

    using System;
    using System.Collections.Generic;
    using System.ComponentModel;
    using System.Data;

    namespace Infrastructure
    {
        public static class EnumerableExtensions
        {
            public static DataTable CopyToDataTable<T>(this IEnumerable<T> array)
            {
                DataTable result = new DataTable();
                foreach (PropertyDescriptor pd in TypeDescriptor.GetProperties(typeof (T)))
                {
                    if (pd.PropertyType.IsGenericType && pd.PropertyType.GetGenericTypeDefinition().Equals(typeof (Nullable<>)))
                        result.Columns.Add(pd.Name,Nullable.GetUnderlyingType(pd.PropertyType));
                    else
                        result.Columns.Add(pd.Name, pd.PropertyType);
                }
                foreach (T item in array)
                {
                    DataRow row = result.NewRow();
                    foreach (PropertyDescriptor pd in TypeDescriptor.GetProperties(typeof(T)))
                        row[pd.Name] = pd.GetValue(item) ?? DBNull.Value;
                    result.Rows.Add(row);
                }
                return result;
            }
        }
    }
    2.调用方式

    List<T> items = new List<T>();

    xxx //为items赋值

    DataTable dataTable = EnumerableExtensions.CopyToDataTable(items);//调用方法

  • 相关阅读:
    JSON操作技巧
    我的前端学习历程(转)
    sql指南网址
    using 和try/catch区别和注意点
    【转】StringBuffer的用法与string的区别
    【转】比较page、request、session、application的使用范围
    【转】StringBuilder用法
    【转】.Net高级技术——IDisposable
    【转】.NET快速查找某个类所在的命名空间
    【转】VS2010安装包制作
  • 原文地址:https://www.cnblogs.com/jeff151013/p/11739359.html
Copyright © 2011-2022 走看看