【问题标题】:Adding a Sheet to an Excel Workbook将工作表添加到 Excel 工作簿
【发布时间】:2017-02-04 01:45:40
【问题描述】:

我正在尝试在 Excel 中创建一个包含多个工作表的Workbook,但我不知道如何创建多个工作表。我可以创建一个就好了,但是当我尝试创建第二个来写入时,我得到了一个错误。

Dim app As Application = New Application
Dim xlApp As New Excel.Application
Dim xlWorkBook As Excel.Workbook
Dim newXlApp As Excel.Application = New Microsoft.Office.Interop.Excel.Application
Dim newXlWorkbook As Excel.Workbook
Dim newXlSheet As Excel.Worksheet
Dim newXlSheet2 As Excel.Worksheet

Public Sub createWorkBook()
    newXlWorkbook = newXlApp.Workbooks.Add()

    newXlSheet = newXlWorkbook.Sheets("Sheet1")
    newXlSheet2 = newXlWorkbook.Sheets.Add("Sheet2")

    newXlSheet.Cells(1, 1) = "Task ID"
    newXlSheet.Cells(1, 2) = "Collective Tasks"
    newXlSheet.Cells(1, 3) = "Supported Task"

    newXlSheet2.Cells(1, 1) = "Parent Collective Task"
    newXlSheet2.Cells(1, 2) = "Individual Task"
End Sub

我不确定它是否重要,但我还有一个单独的 Excel Workbook 打开我正在查询。

【问题讨论】:

  • 哪一行错误?您似乎只在代码中添加了一张工作表。
  • @sjr newXlSheet2 = newXlWorkbook.Sheets.Add("Sheet2") 抛出 An unhandled exception of type 'System.Runtime.InteropServices.COMException' occurred
  • 认为错误是“System.Runtime.InteropServices.COMException”类型的第一次机会异常。如果他们有同样的错误,任何人都可以参考这个问题。

标签: excel vb.net excel-interop


【解决方案1】:

据我所知,您的代码给出的错误是:

“System.Runtime.InteropServices.COMException”类型的第一次机会异常

如果您想将多个表格添加到您的 Excel Workbook 这是执行此操作的代码:

Dim app As New Excel.Application
Dim wb As Excel.Workbook = app.Workbooks.Add()
Dim ws As Excel.Worksheet

ws = CType(wb.Sheets.Add(Count:=10), Excel.Worksheet)

默认情况下,Workbook 带有一个 Sheet。如果您想添加多个集合,Count:= parameter。正如您在我的示例中看到的那样,我使用了 10。这将为我留下 11 张工作表。

请注意,ws 将是 Workbook 中的最后一张表。在我的示例中,这将是 Sheet11

如果您想使用每个Worksheet,那么您需要查看以下代码:

Dim ws1 As Excel.Worksheet = CType(wb.Sheets(1), Excel.Worksheet)
Dim ws2 As Excel.Worksheet = CType(wb.Sheets.Add(), Excel.Worksheet)

ws1.Cells(1, 1) = "Task ID"
ws1.Cells(1, 2) = "Collective Tasks"
ws1.Cells(1, 3) = "Supported Task"

ws2.Cells(1, 1) = "Parent Collective Task"
ws2.Cells(1, 2) = "Individual Task"

请注意,ws1 引用了第一张纸。如上所述,Workbook 默认带有一张。

【讨论】: