C# DataTable转换为Entity(反射&&泛型)
作者:互联网
public static IEnumerableParse(IEnumerablerows) where T : class, new() { if (rows == null || Enumerable.FirstOrDefault(rows) == null) return (IEnumerable) new T[0]; PropertyInfo[] properties = typeof (T).GetProperties(BindingFlags.Instance | BindingFlags.Public | BindingFlags.SetProperty); Listlist = new List(); foreach (DataRow row in rows) { T instance = Activator.CreateInstance(); DbHelper.Parse((object) instance, (IEnumerable) properties, row); list.Add(instance); } return (IEnumerable) list; } private static void Parse(object obj, IEnumerableproperties, DataRow row) { foreach (PropertyInfo propertyInfo in properties) { if (DataRowExtension.HasValue(row, propertyInfo.Name)) { try { propertyInfo.SetValue(obj, DbHelper.ConvertType(CultureInfo.CurrentCulture, row[propertyInfo.Name], propertyInfo.PropertyType), (object[]) null); } } catch{ } } }
标签:rows,C#,IEnumerable,Entity,&&,propertyInfo,null,properties,row 来源: https://blog.51cto.com/u_15180952/2732446