lunes, 5 de mayo de 2014

¿Cómo pasar un List<> (lista genérica) a un DataTable?

El día de hoy quiero compartirles la solución a este problema que se me presento.

En mi capa de acceso a datos estoy utilizando LinQ junto con Entities para hacer la consultas a la BD, todo funciona de maravilla sin embargo me tope con la necesidad de pasar una lista ó IEnumerable a un DataTable y preguntándole a mi tio Google encontré este método que me saco del problema.
 
Les comparto la información y espero que les sea de utilidad!


public static DataTable LINQToDataTable<T>(IEnumerable<T> varlist)
        {
            DataTable dtReturn = new DataTable();
            PropertyInfo[] oProps = null;

            if (varlist == null) return dtReturn;
            foreach (T rec in varlist)
            {
                if (oProps == null)
                {
                    oProps = ((Type)rec.GetType()).GetProperties();
                    foreach (PropertyInfo pi in oProps)
                    {
                        Type colType = pi.PropertyType;
                        if ((colType.IsGenericType) && (colType.GetGenericTypeDefinition() == typeof(Nullable<>)))
                        {
                            colType = colType.GetGenericArguments()[0];
                        }
                        dtReturn.Columns.Add(new
                        DataColumn(pi.Name, colType));
                    }
                }
                DataRow dr = dtReturn.NewRow();
                foreach (PropertyInfo pi in oProps)
                {
                    dr[pi.Name] = pi.GetValue(rec, null) == null ? DBNull.Value : pi.GetValue(rec, null);
                }
                dtReturn.Rows.Add(dr);
            }
            return dtReturn;
        }