相关疑难解决方法(0)

如何将List <T>转换为DataSet?

给定一个对象列表,我需要将其转换为数据集,其中列表中的每个项目由一行表示,每个属性都是行中的一列.然后将此DataSet传递给Aspose.Cells函数,以便将Excel文档创建为报表.

说我有以下内容:

public class Record
{
   public int ID { get; set; }
   public bool Status { get; set; }
   public string Message { get; set; }
}
Run Code Online (Sandbox Code Playgroud)

给定List记录,如何将其转换为DataSet,如下所示:

ID Status Message
1  true   "message" 
2  false  "message2" 
3  true   "message3" 
...
Run Code Online (Sandbox Code Playgroud)

目前我能想到的唯一一件事如下:

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);
}
Run Code Online (Sandbox Code Playgroud)

但这种方式让我觉得必须有一个更好的方法,因为至少如果将新属性添加到R​​ecord中,那么它们将不会显示在DataSet中......但同时它允许我控制每个属性被添加到行中.

有谁知道更好的方法吗?

c# transformation list dataset

15
推荐指数
1
解决办法
4万
查看次数

标签 统计

c# ×1

dataset ×1

list ×1

transformation ×1