• 将一个列表转换成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;
            }

  • 相关阅读:
    JQuery之动画效果
    JS (随着鼠标的移动,旁边显示放大图)
    jQuery 事件和动画
    jQuery 概述
    CSS (层叠样式表)
    css的文章部分的基本语句
    HTML基本语法
    Web
    JavaScript预解析案例,JavaScript预解析题目
    JavaScript预解析 变量提升与函数提升
  • 原文地址:https://www.cnblogs.com/dullbaby/p/2949958.html
Copyright © 2020-2023  润新知