public static List<T> ConvertTo<T>(DataTable table)
{
if (table == null)
{
return null;
}
List<DataRow> rows = new List<DataRow>();
foreach (DataRow row in table.Rows)
{
rows.Add(row);
}
return ConvertTo<T>(rows);
}
public static List<T> ConvertTo<T>(IList<DataRow> rows)
{
List<T> list = null;
if (rows != null)
{
list = new List<T>();
foreach (DataRow row in rows)
{
T item = CreateItem<T>(row);
list.Add(item);
}
}
return list;
}
public static T CreateItem<T>(DataRow row)
{
T obj = default(T);
if (row != null)
{
obj = Activator.CreateInstance<T>();
foreach (DataColumn column in row.Table.Columns)
{
PropertyInfo prop = obj.GetType().GetProperty(column.ColumnName);
if (prop == null || !prop.CanWrite) continue;
Type t1 = prop.PropertyType;
try
{
object value = row[column.ColumnName];
if (value != DBNull.Value)
{
//t1 = value.GetType();
//可空类型会报错
//prop.SetValue(obj, Convert.ChangeType(value, t1), null);
prop.SetValue(obj, ChanageType(value, t1), null);
}
}
catch { }
}
}
return obj;
}
//转换可空类型 如:DateTime?
internal static object ChanageType(object value, Type convertsionType)
{
//判断convertsionType类型是否为泛型,因为nullable是泛型类,
if (convertsionType.IsGenericType &&
//判断convertsionType是否为nullable泛型类
convertsionType.GetGenericTypeDefinition().Equals(typeof(Nullable<>)))
{
if (value == null || value.ToString().Length == 0)
{
return null;
}
//如果convertsionType为nullable类,声明一个NullableConverter类,该类提供从Nullable类到基础基元类型的转换
System.ComponentModel.NullableConverter nullableConverter = new System.ComponentModel.NullableConverter(convertsionType);
//将convertsionType转换为nullable对的基础基元类型
convertsionType = nullableConverter.UnderlyingType;
}
return Convert.ChangeType(value, convertsionType);
}
//Type t1
//MethodInfo mi = FormatDataTable.Instance.GetType().GetMethod("ConvertType").MakeGenericMethod(t1);
//mi.Invoke(FormatDataTable.Instance, new object[] { value });
/// <summary>
/// 泛型类型转换
/// </summary>
/// <typeparam name="T">要转换的基础类型</typeparam>
/// <param name="val">要转换的值</param>
/// <returns></returns>
/// <remark>
/// by mcjiffy.cn
/// </remark>
public static T ConvertType<T>(object val)
{
if (val == null) return default(T);//返回类型的默认值
Type tp = typeof(T);
//泛型Nullable判断,取其中的类型
if (tp.IsGenericType)
{
tp = tp.GetGenericArguments()[0];
}
//string直接返回转换
if (tp.Name.ToLower() == "string")
{
return (T)val;
}
//反射获取TryParse方法
var TryParse = tp.GetMethod("TryParse", BindingFlags.Public | BindingFlags.Static, Type.DefaultBinder,
new Type[] { typeof(string), tp.MakeByRefType() },
new ParameterModifier[] { new ParameterModifier(2) });
var parameters = new object[] { val, Activator.CreateInstance(tp) };
bool success = (bool)TryParse.Invoke(null, parameters);
//成功返回转换后的值,否则返回类型的默认值
if (success)
{
return (T)parameters[1];
}
return default(T);
}
超高性能DataTable转换到List,并解决可空类型转换
于 2022-01-21 02:13:44 首次发布