【发布时间】:2010-10-06 02:34:48
【问题描述】:
给定一个对象列表,我需要将其转换为一个数据集,其中列表中的每个项目由一行表示,每个属性是该行中的一列。然后,此 DataSet 将被传递给 Aspose.Cells 函数,以创建 Excel 文档作为报告。
假设我有以下内容:
public class Record
{
public int ID { get; set; }
public bool Status { get; set; }
public string Message { get; set; }
}
给定一个 List 记录,我如何将其转换为 DataSet,如下所示:
ID Status Message
1 true "message"
2 false "message2"
3 true "message3"
...
目前我唯一能想到的如下:
DataSet ds = new DataSet
ds.Tables.Add();
ds.Tables[0].Add("ID", typeof(int));
ds.Tables[0].Add("Status", typeof(bool));
ds.Tables[0].Add("Message", typeof(string));
foreach(Record record in records)
{
ds.Tables[0].Rows.Add(record.ID, record.Status, record.Message);
}
但是这种方式让我认为必须有更好的方法,因为至少如果将新属性添加到 Record 中,那么它们不会出现在 DataSet 中......但同时它允许我控制每个属性添加到行中的顺序。
有人知道更好的方法吗?
【问题讨论】:
标签: c# list dataset transformation