Linq Result To Datatable

本文介绍了一种使用C#将泛型集合转换为DataTable的方法。通过定义一个扩展方法,该方法遍历泛型集合的每个元素并将其属性映射到DataTable的列中,从而实现了类型安全的数据转换。此外,还展示了如何调用此方法来处理DataTable数据。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

public static DataTable ToDataTable<TSource>(this IEnumerable<TSource> source )
        {
            if ( source == null )
                return null;

            DataTable table = new DataTable ( );

            PropertyInfo [] oProps = null;

            foreach ( TSource item in source )
            {
                if ( oProps == null )
                {
                    oProps = ( ( Type ) item . GetType ( ) ) . GetProperties ( );
                    foreach ( PropertyInfo pro in oProps )
                    {
                        Type colType = pro . PropertyType;
                        if ( ( colType . IsGenericType ) && ( colType . GetGenericTypeDefinition ( ) == typeof ( Nullable<> ) ) )
                        {
                            colType = colType . GetGenericArguments ( ) [ 0 ];
                        }
                        table . Columns . Add ( new DataColumn ( pro . Name , colType ) );
                    }
                }

                DataRow row = table . NewRow ( );
                foreach ( PropertyInfo info in oProps )
                {
                    row [ info . Name ] = info . GetValue ( item , null ) ?? DBNull . Value;
                }
                table . Rows . Add ( row );
            }

            return table;
        } 
//调用方法

var query = table.AsEnumerable().Select ( ( x ) => new{
x1=x . Field<int> ( "x1" ),
x2=x . Field<int> ( "x2" ) 
}). ToDataTable ( );

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值