首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >取消列出后删除Excel ListObject

取消列出后删除Excel ListObject
EN

Stack Overflow用户
提问于 2017-08-19 02:20:12
回答 1查看 242关注 0票数 1

我正在用C#做一个VSTO插件项目。

基本上,我想从数据库中检索数据并将其放到excel中。但是,我只想以简单范围的格式编写数据,而不是保持对数据源的任何类型的绑定。

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

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

代码如下:

代码语言:javascript
复制
   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);

我还尝试了一些变体来删除listobject,但都不起作用:

代码语言:javascript
复制
extendedWorksheet.Controls.Remove("list1');
//or
listObject.Delete()
//or
foreach (ListObject x in extendedWorksheet.Controls)
{
    x.Delete();
}
EN

回答 1

Stack Overflow用户

发布于 2020-05-28 03:42:07

foreach ( extendedWorksheet.ListObjects)中的ListObject x

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/45762816

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档