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);//调用方法

  • 相关阅读:
    一步步学习SPD2010--第十一章节--处理母版页(10)--重置母版页到网站定义
    pandas转numpy并打平实例
    list和numpy互相转换
    pandas转numpy
    pandas库疑难问题---2、pandas切片操作
    pandas切片操作
    pandas中的iloc和loc用法的区别
    NumPy疑难问题---1、NumPy切片操作
    numpy切片操作
    python疑难问题---13、Python切片操作
  • 原文地址:https://www.cnblogs.com/jeff151013/p/11739359.html
Copyright © 2011-2022 走看看