我使用FastMember库将对象列表转换为dataTable但它返回空对象,所以任何人都可以帮我解决这个问题
List<object> list = new List<object>() { new { Number = 500 } };
DataTable table = new DataTable();
using (var reader = ObjectReader.Create(list))
{
table.Load(reader);
}
答案 0 :(得分:3)
显然,Fastmember无法枚举匿名对象的属性。因此,创建的数据读取器没有列,DataTable.Load方法拒绝为此读取器创建空行。
如果可以,请尝试使用具体类:
class Thingy
{
public int Number { get; set; }
}
class Program
{
static void Main(string[] args)
{
List<Thingy> list = new List<Thingy>() { new Thingy { Number = 500 } };
DataTable table = new DataTable();
using (var reader = ObjectReader.Create(list))
{
table.Load(reader);
}
}
}
编辑:实际上,Fastmember完全能够访问这些属性,但通用List(对象)的类型阻止它看到它们。如果您可以提供具有实际运行时类型的IEnumerable,它也应该有效:
//This creates a "strongly" typed list, instead of List<object>:
var list = new[] { (new { Number = 500 }) }.ToList();
DataTable table = new DataTable();
using (var reader = ObjectReader.Create(list))
{
table.Load(reader);
}
编辑2:还有另一种方法可以使用构造函数将类型信息传递给Fastmember:
List<object> list = new List<object> { new { Number = 500 } };
DataTable table = new DataTable();
// Note that type information is derived directly from the first object in the list,
// so try not to pass an empty one :)
using (var reader = new ObjectReader(list[0].GetType(), list, null))
{
table.Load(reader);
}
另请注意,这比其他方法更具风险,因为可以创建包含混合项类型的列表。 Fastmember需要列表中的每个项目具有完全相同的类型,类似下面的内容将导致异常:
//These two items are not of the same type. Look carefully at the "Extra" property:
List<object> list = new List<object> { new { Number = 500, Extra = true }, new { Number = 500, Extra = "Boom" } };