首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >从C#代码激活Excel ComAddin

从C#代码激活Excel ComAddin
EN

Stack Overflow用户
提问于 2012-02-10 20:57:21
回答 1查看 2.4K关注 0票数 0

实际上,我有一个正在运行的C#应用程序。

当它启动时,它运行一个excel实例并将其保存到一个变量中:

excelApp = new Excel.Application();

然后我循环浏览每个excel的加载项,找到我自己创建的added:

代码语言:javascript
复制
    private void getAddin()
    {
        const string addinName = "myAddInName";

        foreach (Office.COMAddIn addin in excelApp.COMAddIns)
            if (addin.Description.ToUpper().Contains(addinName.ToUpper()))
            {
                myAddin = addin;
                return;
            }
    }

问题是,我的插件可能在停用的元素列表中。(由于一些崩溃)

然后我必须转到(在excel的框架上):

File >Options >AddIns >Manage >Deactivated elements >Achieve >"myAddin" >Activate

要使我的外接程序再次工作(在excel重新启动后)...

我尝试使用插件的属性来重新激活它,但在这种情况下可能会再次导致应用程序崩溃。

代码语言:javascript
复制
            myAddin.Connect = loadAddin;

有人知道如何解决这个问题/使用C#自动重新激活禁用的插件吗?

EN

回答 1

Stack Overflow用户

发布于 2012-05-15 04:35:58

这应该会对http://msdn.microsoft.com/en-us/library/aa662931(v=office.11).aspx有所帮助

我相信你需要做的是

代码语言:javascript
复制
if(!myAddin.Connect)
{
     myAddin.Connect =true;
}
票数 3
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/9228155

复制
相关文章

相似问题

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