zoukankan      html  css  js  c++  java
  • 将一个列表转换成DataTable,如果列表为空将返回空的DataTable结构

         /// <summary>
            /// 将一个列表转换成DataTable,如果列表为空将返回空的DataTable结构
            /// </summary>
            /// <typeparam name="T">要转换的数据类型</typeparam>
            /// <param name="entityList">实体对象列表</param>
            public static DataTable EntityListToDataTable<T>(List<T> entityList)
            {
                DataTable dt = new DataTable();

                //取类型T所有Propertie
                Type entityType = typeof(T);
                PropertyInfo[] entityProperties = entityType.GetProperties();
                Type colType = null;
                foreach (PropertyInfo propInfo in entityProperties)
                {

                    if (propInfo.PropertyType.IsGenericType)
                    {
                        colType = Nullable.GetUnderlyingType(propInfo.PropertyType);
                    }
                    else
                    {
                        colType = propInfo.PropertyType;
                    }

                    if (colType.FullName.StartsWith("System"))
                    {
                        dt.Columns.Add(propInfo.Name, colType);
                    }
                }

                if (entityList != null && entityList.Count > 0)
                {
                    foreach (T entity in entityList)
                    {
                        DataRow newRow = dt.NewRow();
                        foreach (PropertyInfo propInfo in entityProperties)
                        {
                            if (dt.Columns.Contains(propInfo.Name))
                            {
                                object objValue = propInfo.GetValue(entity, null);
                                newRow[propInfo.Name] = objValue == null ? DBNull.Value : objValue;
                            }
                        }
                        dt.Rows.Add(newRow);
                    }
                }

                return dt;
            }

  • 相关阅读:
    【安卓本卓】Android系统源码篇之(一)源码获取、源码目录结构及源码阅读工具简介
    【朝花夕拾】Android性能篇之(六)Android进程管理机制
    【烂笔头】adb命令篇
    【朝花夕拾】Android性能篇之(五)Android虚拟机
    【朝花夕拾】Android性能篇之(一)序言及JVM
    【烂笔头】git常用命令篇
    【朝花夕拾】Android性能篇之(四)Apk打包
    【朝花夕拾】Android Log篇
    从2015年百度站长的一则公告回头看百度的骚操作
    ASP.NET Core+Quartz.Net 实现web定时任务
  • 原文地址:https://www.cnblogs.com/dullbaby/p/2949958.html
Copyright © 2011-2022 走看看