【问题标题】:Deleting Excel ListObject after Unlisting it取消列出后删除 Excel ListObject
【发布时间】:2017-08-18 18:20:12
【问题描述】:

我正在用 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】:

    foreach (ListObject x in extendedWorksheet.ListObjects)

    【讨论】:

      猜你喜欢
      • 1970-01-01
      • 2016-07-20
      • 1970-01-01
      • 2019-07-16
      • 2012-11-25
      • 1970-01-01
      • 2018-08-22
      • 2019-05-14
      • 2019-05-04
      相关资源
      最近更新 更多