How do you convert a DataTable into a generic list?

前端 未结 27 2592
后悔当初
后悔当初 2020-11-22 17:04

Currently, I\'m using:

DataTable dt = CreateDataTableInSomeWay();

List list = new List(); 
foreach (DataRow dr in dt.Rows)
{
          


        
27条回答
  •  遇见更好的自我
    2020-11-22 17:31

            /* This is a generic method that will convert any type of DataTable to a List 
             * 
             * 
             * Example :    List< Student > studentDetails = new List< Student >();  
             *              studentDetails = ConvertDataTable< Student >(dt);  
             *
             * Warning : In this case the DataTable column's name and class property name
             *           should be the same otherwise this function will not work properly
             */
    

    The following are the two functions in which if we pass a DataTable and a user defined class. It will then return the List of that class with the DataTable data.

            public static List ConvertDataTable(DataTable dt)
            {
                List data = new List();
                foreach (DataRow row in dt.Rows)
                {
                    T item = GetItem(row);
                    data.Add(item);
                }
                return data;
            }
    
    
            private static T GetItem(DataRow dr)
            {
                Type temp = typeof(T);
                T obj = Activator.CreateInstance();
    
                foreach (DataColumn column in dr.Table.Columns)
                {
                    foreach (PropertyInfo pro in temp.GetProperties())
                    {
                       //in case you have a enum/GUID datatype in your model
                       //We will check field's dataType, and convert the value in it.
                        if (pro.Name == column.ColumnName){                
                        try
                        {
                            var convertedValue = GetValueByDataType(pro.PropertyType, dr[column.ColumnName]);
                            pro.SetValue(obj, convertedValue, null);
                        }
                        catch (Exception e)
                        {         
                           //ex handle code                   
                            throw;
                        }
                            //pro.SetValue(obj, dr[column.ColumnName], null);
                    }
                        else
                            continue;
                    }
                }
                return obj;
            }
    

    This method will check the datatype of field, and convert dataTable value in to that datatype.

        private static object GetValueByDataType(Type propertyType, object o)
        {
            if (o.ToString() == "null")
            {
                return null;
            }
            if (propertyType == (typeof(Guid)) || propertyType == typeof(Guid?))
            {
                return Guid.Parse(o.ToString());
            }
            else if (propertyType == typeof(int) || propertyType.IsEnum) 
            {
                return Convert.ToInt32(o);
            }
            else if (propertyType == typeof(decimal) )
            {
                return Convert.ToDecimal(o);
            }
            else if (propertyType == typeof(long))
            {
                return Convert.ToInt64(o);
            }
            else if (propertyType == typeof(bool) || propertyType == typeof(bool?))
            {
                return Convert.ToBoolean(o);
            }
            else if (propertyType == typeof(DateTime) || propertyType == typeof(DateTime?))
            {
                return Convert.ToDateTime(o);
            }
            return o.ToString();
        }
    

    To call the preceding method, use the following syntax:

    List< Student > studentDetails = new List< Student >();  
    studentDetails = ConvertDataTable< Student >(dt); 
    

    Change the Student class name and dt value based on your requirements. In this case the DataTable column's name and class property name should be the same otherwise this function will not work properly.

提交回复
热议问题