创建CreatDataTable

 public static DataTable CreateDataTable<T>(this IEnumerable<T> arry)
        {
            Type type = typeof(T);
            var ret = new DataTable();
            ret.TableName = type.Name;
            foreach (PropertyInfo item in type.GetProperties())
            {
                if (item.PropertyType.FullName.Contains("Nullable") && item.PropertyType.FullName.Contains("Int32"))
                    ret.Columns.Add(new DataColumn(item.Name, typeof(int)));
                else if (item.PropertyType.FullName.Contains("Nullable") && item.PropertyType.FullName.Contains("Decimal"))
                    ret.Columns.Add(new DataColumn(item.Name, typeof(decimal)));
                else if (item.PropertyType.FullName.Contains("Nullable") && item.PropertyType.FullName.Contains("Boolean"))
                    ret.Columns.Add(new DataColumn(item.Name, typeof(bool)));
                else if (item.PropertyType.FullName.Contains("Nullable") && item.PropertyType.FullName.Contains("DateTime"))
                    ret.Columns.Add(new DataColumn(item.Name, typeof(DateTime)));
                else
                    ret.Columns.Add(new DataColumn(item.Name, item.PropertyType));
            }
            foreach (T item in arry)
            {
                var Row = ret.NewRow();
                foreach (PropertyInfo pi in type.GetProperties())
                {
                    if (pi.GetValue(item, null) == null)
                    {
                        Row[pi.Name] = DBNull.Value;
                    }
                    else
                    {
                        Row[pi.Name] = pi.GetValue(item, null);
                    }
                }
                ret.Rows.Add(Row);
            }
            return ret;
        }
        public static DataTable CreateDataTable<T>(this IEnumerable<T> arry, string tbName)
        {
            Type type = typeof(T);
            var ret = new DataTable();
            ret.TableName = tbName;
            foreach (PropertyInfo item in type.GetProperties())
            {
                if (item.PropertyType.FullName.Contains("Nullable") && item.PropertyType.FullName.Contains("Int32"))
                    ret.Columns.Add(new DataColumn(item.Name, typeof(int)));
                else if (item.PropertyType.FullName.Contains("Nullable") && item.PropertyType.FullName.Contains("Decimal"))
                    ret.Columns.Add(new DataColumn(item.Name, typeof(decimal)));
                else if (item.PropertyType.FullName.Contains("Nullable") && item.PropertyType.FullName.Contains("Boolean"))
                    ret.Columns.Add(new DataColumn(item.Name, typeof(bool)));
                else if (item.PropertyType.FullName.Contains("Nullable") && item.PropertyType.FullName.Contains("DateTime"))
                    ret.Columns.Add(new DataColumn(item.Name, typeof(DateTime)));
                else
                    ret.Columns.Add(new DataColumn(item.Name, item.PropertyType));
            }
            foreach (T item in arry)
            {
                var Row = ret.NewRow();
                foreach (PropertyInfo pi in type.GetProperties())
                {
                    if (pi.GetValue(item, null) == null)
                    {
                        Row[pi.Name] = DBNull.Value;
                    }
                    else
                    {
                        Row[pi.Name] = pi.GetValue(item, null);
                    }
                }
                ret.Rows.Add(Row);
            }
            return ret;
        }


    }
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值