我有一个对象列表如下:
List<UserTransactionDTO>
我希望将此列表转移到Datatable
。
我搜索并找到以下链接:
Convert generic List/Enumerable to DataTable?
它适用于我,但我不知道如何实现HyperDescriptor
以使其更快。是否有一些dll可以使用?
我只是在上一个链接中使用以下代码,它工作正常:
public static DataTable ToDataTable<T>(this IList<T> data)
{
PropertyDescriptorCollection props =
TypeDescriptor.GetProperties(typeof(T));
DataTable table = new DataTable();
for(int i = 0 ; i < props.Count ; i++)
{
PropertyDescriptor prop = props[i];
table.Columns.Add(prop.Name, prop.PropertyType);
}
object[] values = new object[props.Count];
foreach (T item in data)
{
for (int i = 0; i < values.Length; i++)
{
values[i] = props[i].GetValue(item);
}
table.Rows.Add(values);
}
return table;
}
答案 0 :(得分:3)
很简单。在项目中引用HyperDescriptor库,并在应用程序初始化中为每个类型调用一次,以使每个类型的描述符为“hyper”:
Hyper.ComponentModel.HyperTypeDescriptionProvider.Add(typeof(MyType))
或者,您可以使用我在项目评论中提供的HyperTypeDescriptionProvider
版本HyperDescriptor at CodeProject。它解决了我发现的一些问题,包括尝试将类型及其基类型添加到HyperTypeDescriptionProvider
时的堆栈溢出问题。如果你这样做,你可以简单地在你的函数中进行Add()
调用,并且不会发生坏事,因为具有相同类型的第二次调用不会在我的版本中添加两次类型。在ToDataTable<T>()
功能的顶部,添加以下行:
Hyper.ComponentModel.HyperTypeDescriptionProvider.Add(typeof(T))
无论您采用哪种方式,都不要忘记在之前/之后进行基准测试,以确保获得性能优势。
P.S。我非常感谢Marc Gravell他在HyperDescriptor上的工作,我认为它是一种非常漂亮和有用的魔法。