using System;
using System.Collections.Generic;
using System.Data;
using System.Linq;
using System.Reflection;
using System.Text;
using System.Threading.Tasks;
namespace WindowsFormsApplication1
{
// class GenericList
public class GetEntityList<T>:List<T>
{
/// <summary>
/// 获得实体集合
/// </summary>
/// <param name="dt">数据表</param>
/// <param name="f">类名称</param>
public GetEntityList(DataTable dt, string f)
{
//第一步:创建对象实例||||||||Activator.CreateInstance
System.Type obType= System.Type.GetType(f);//获取指定名称的类型
object Instance = Activator.CreateInstance(obType, null);//创建指定类型实例
//第二步:获取指定对象的所有公共属性 ||||对象.GetType().GetProperties();
PropertyInfo[] fields = Instance.GetType().GetProperties();
//第三步:在DataTable中遍历所有行,将值赋值给相应的属性
foreach (DataRow dr in dt.Rows)
{
object obj = Activator.CreateInstance(obType, null);
foreach (DataColumn dc in dt.Columns)
{
foreach (PropertyInfo t in fields)
{
//根据条件DataColumn列名称与属性名称相等
if (dc.ColumnName == t.Name)
{
//属性类将值复制个相应的属性即可
t.SetValue(obj, dr[dc.ColumnName], null);//给对象赋值
continue;
}
}
}
this.Add((T)obj);//将对象填充到list集合
}
}
}
}
实体类
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
namespace WindowsFormsApplication1
{
//[MetadataType(typeof(EmployeeData))]
public class People
{
public int ID { set; get;}
public string Uname { set; get;}
public bool Sex { set; get;}
}
}
测试调用:
DataTable dt = new DataTable("People");
DataColumn dc1 = new DataColumn("ID", Type.GetType("System.Int32"));
DataColumn dc2 = new DataColumn("Uname", Type.GetType("System.String"));
DataColumn dc3 = new DataColumn("Sex", Type.GetType("System.Boolean"));
dt.Columns.Add(dc1);
dt.Columns.Add(dc2);
dt.Columns.Add(dc3);