public static DataTable Convert<T>(IList<T> list)
{
if (list == null || list.Count <= 0)
{
return null;
}
DataTable dt = new DataTable(typeof(T).Name);
DataColumn dc;
DataRow dr;
PropertyInfo[] propertyInfo = typeof(T).GetProperties(BindingFlags.Public | BindingFlags.Instance);
foreach (T t in list)
{
if (t == null)
{
continue;
}
dr = dt.NewRow();
for (int i = 0, j = propertyInfo.Length; i < j; i++)
{
PropertyInfo pi = propertyInfo[i];
string name = pi.Name;
if (dt.Columns[name] == null)
{
dc = new DataColumn(name, pi.PropertyType);
dt.Columns.Add(dc);
}
dr[name] = pi.GetValue(t, null);
}
dt.Rows.Add(dr);
}
return dt;
}
本文介绍了一种将C#中的泛型列表转换为DataTable的方法。该方法首先检查输入列表是否为空或为null,然后创建一个新的DataTable,并从泛型类型获取其公共属性。接下来,对于列表中的每个元素,创建一个新的DataRow并填充数据。
426

被折叠的 条评论
为什么被折叠?



