取消列出后删除Excel ListObject

问题描述 投票:1回答:1

我正在用C#执行VSTO外接程序项目。

基本上,我想从数据库中检索数据并将其放入excel。但是,我只想以简单范围的格式写入数据,并且不要保留任何与数据源的绑定。

为此,我正在创建一个ListObject并将其数据源设置为填充有数据的数据表。然后,我调用方法Unlist将表转换回正常范围,并且他们试图从工作表中删除列表对象,以便在重复此过程时可以使用相同的列表对象名称。

问题是,当我尝试删除列表对象时,C#抛出了错误的索引异常。

这里是代码:

   Microsoft.Office.Interop.Excel.Worksheet worksheet = (Microsoft.Office.Interop.Excel.Worksheet)Globals.ThisAddIn.Application.ActiveSheet;

    Worksheet extendedWorksheet = Globals.Factory.GetVstoObject(worksheet);

    Microsoft.Office.Interop.Excel.Range cell = extendedWorksheet.Application.ActiveCell;
    Microsoft.Office.Tools.Excel.ListObject listObject;
    BindingSource bindingSource = new System.Windows.Forms.BindingSource();
    DataTable dataTable = new DataTable();
    bindingSource.DataSource = dataTable;
    listObject = extendedWorksheet.Controls.AddListObject(cell, "list1");
    listObject.AutoSetDataBoundColumnHeaders = true;
    listObject.SetDataBinding(bindingSource, "");
    listObject.Unlist();
    extendedWorksheet.Controls.RemoveAt(0);

我还尝试了一些删除列表对象的变体,但没有一个起作用:

extendedWorksheet.Controls.Remove("list1');
//or
listObject.Delete()
//or
foreach (ListObject x in extendedWorksheet.Controls)
{
    x.Delete();
}
c# excel vsto
1个回答
0
投票

foreach(extendedWorksheet.ListObject s中的ListObject x)] >>

© www.soinside.com 2019 - 2024. All rights reserved.