如何使用 C# 从 DataSet 创建包含多个工作表的 excel 文件

Posted

技术标签:

【中文标题】如何使用 C# 从 DataSet 创建包含多个工作表的 excel 文件【英文标题】:How to create excel file with multiple sheets from DataSet using C# 【发布时间】:2011-12-30 16:39:09 【问题描述】:

。我已经成功创建了一个带有单张工作表的 excel 文件。但我无法为多张纸做到这一点。

问候 严厉的

【问题讨论】:

我想这取决于您如何看待创建 excel 文件。您是否正在寻找@为数据集中的每个表创建一个页面? 您可能更改了默认的 Excel 行为。见***.com/questions/8066189/… 您正在为已创建的单张工作表使用哪种技术或组件? 【参考方案1】:

这是一个简单的 C# 类,它以编程方式创建 Excel 工作簿并向其中添加两个工作表,然后填充两个工作表。最后,它将 WorkBook 保存到应用程序根目录中的一个文件中,以便您检查结果...

public class Tyburn1

    object missing = Type.Missing;
    public Tyburn1()
    
        Excel.Application oXL = new Excel.Application();
        oXL.Visible = false;
        Excel.Workbook oWB = oXL.Workbooks.Add(missing);
        Excel.Worksheet oSheet = oWB.ActiveSheet as Excel.Worksheet;
        oSheet.Name = "The first sheet";
        oSheet.Cells[1, 1] = "Something";
        Excel.Worksheet oSheet2 = oWB.Sheets.Add(missing, missing, 1, missing) 
                        as Excel.Worksheet;
        oSheet2.Name = "The second sheet";
        oSheet2.Cells[1, 1] = "Something completely different";
        string fileName = Path.GetDirectoryName(Assembly.GetExecutingAssembly().Location)        
                                + "\\SoSample.xlsx";
        oWB.SaveAs(fileName, Excel.XlFileFormat.xlOpenXMLWorkbook,
            missing, missing, missing, missing,
            Excel.XlSaveAsAccessMode.xlNoChange,
            missing, missing, missing, missing, missing);
        oWB.Close(missing, missing, missing);
        oXL.UserControl = true;
        oXL.Quit();
    

为此,您需要在项目中添加对 Microsoft.Office.Interop.Excel 的引用(您可能已经这样做了,因为您正在创建一张工作表)。

添加第二张表的语句是...

Excel.Worksheet oSheet2 = oWB.Sheets.Add(missing, missing, 1, missing) 
                            as Excel.Worksheet;

“1”参数指定一个工作表,如果您想一次添加多个工作表,它可以更多。

最后说明:声明 oXL.Visible = false;告诉 Excel 以静默模式启动。

【讨论】:

我在 oXL.Quit() 上得到一个错误;每次。 Excel Undantagskod:xc0000005 Felförskjutning:0x000000000000f993。错误被放入机器的事件日志中。您还需要 C# 4 中缺少的参数吗?动态 oWB= excelApplication.Workbooks.Add(); 还不够吗?【参考方案2】:
var groupedSheetList = UserData
    .GroupBy (u => u.date)
    .Select (grp => grp.ToList ())
    .ToList ();

你可以试试这个

using (var package = new ExcelPackage ()) 
    
        foreach (var item in groupedSheetList) 
            var workSheet = package.Workbook.Worksheets.Add (item[0].date);
    

【讨论】:

以上是关于如何使用 C# 从 DataSet 创建包含多个工作表的 excel 文件的主要内容,如果未能解决你的问题,请参考以下文章

如何在 C# 中使用 DataSet Designer 生成的方法?

c# winform 一个dategridview 同时显示几张数据表

C# - 数据集(/插入/更新多个表)

C# 通过DataSet 获取SQL 存储过程返回的多个结果集(tables)

聚合 C# 数据集时,如何将 DataSet 转换为 .Load() 的 DataTable 数组?

C# DataSet与DataTable的区别和用法