当前位置: 首页 > 知识库问答 >
问题:

Excel-DNA:ExcelCommand与ExcelDNA.Registration包共存

叶鹭洋
2023-03-14

我想在使用ExcelDNA注册包的C#程序中编写ExcelCommand UDF。

但是,为了使用注册包,如果我在dna文件中设置explicitRegistraiton=“true”,则无法加载以下简单的Excel命令。 实际上,编译是可能的,但是UDF命令不会出现在Excel外接程序选项卡中。

如何在使用ExcelDna注册的程序中使用excel命令?

// C# program
    [ExcelCommand(MenuName ="Test", MenuText ="Test")]
    public static void SayHelloCommand()
    {   
        MessageBox.Show("Hello");
    }

// .dna file
    <DnaLibrary Name="Registration.Sample Add-In" RuntimeVersion="v4.0" >
      <ExternalLibrary Path="Registration.Sample.dll" ExplicitRegistration="true" LoadFromBytes="true" Pack="true" />
      <Reference Path="ExcelDna.Registration.dll" Pack="true" />
    </DnaLibrary>

共有1个答案

东门理
2023-03-14

一旦将explicitRegistration设置为true,Excel-DNA就会要求您自己注册函数和命令。

与调用ExcelRegistration.GetExcelFunctions().RegisterFunctions()注册函数相同,也可以调用ExcelRegistration.GetExcelCommands().RegisterCommands()注册命令。

例如。

public class AddIn : IExcelAddIn
{
    public void AutoOpen()
    {
        ExcelRegistration
            .GetExcelCommands()
            .RegisterCommands();

        // ...
    }

    public void AutoClose()
    {
        // ...
    }
}
 类似资料:
  • 问题内容: Java即将接近第7版。在我看来,必须有大量的教科书和培训手册在其中,它们教授基于旧版Java的方法,而现在所教的方法将具有更好的解决方案。 有哪些样板代码情况,特别是您看到人们通过习惯的力量实现的情况,您发现自己可以重构以利用最新版本的Java? 问题答案: 枚举。更换 与

  • 0.3 新版功能. Python 拥有的交互式 Shell 是人人都喜欢它的一个重要原因。交互式 Shell 允许你实时的运行 Python 命令并且立即得到返回结果。Flask 本身并未内置 一个交互式 Shell ,因为它并不需要任何前台的特殊设置,仅仅导入您的应用 然后开始探索和使用即可。 然而这里有一些易于获得的助手,可以帮助您在 Shell 遨游时获得更为 愉悦的体验。交互式控制台回话的

  • 本文向大家介绍公共POI导出Excel方法详解,包括了公共POI导出Excel方法详解的使用技巧和注意事项,需要的朋友参考一下 最早开始的时候做过一些数据Excel导出的功能,但是到后期每一次导出都需要写一些差不多类似的代码,稍微研究了一下写了个公共的导出方法。 这里用的是POI,然后写成了一个公共类,传入设置好格式的数据,就能弹出下载框。 (补充下getResponse的方法,之前没注意这个有继

  • 6.5. 与 Directory 共事 os.path 模块有几个操作文件和目录的函数。 这里, 我们看看如何操作路径名和列出一个目录的内容。 例 6.16. 构造路径名 >>> import os >>> os.path.join("c:\\music\\ap\\", "mahadeva.mp3") 'c:\\music\\ap\\mahadeva.mp3' >>> os.path.joi

  • 网上可能找不到的集合框架(暂时只有区间树的一个扩展) 给定区间范围[1,5],[1,6],[2,10],[6,10],[4,19],[5,20],返回关键值“10”的所有区间范围[2,10],[6,10],[4,19],[5,20]。 红黑树部分使用JDK自带的TreeMap,在此之上进行扩展。 声明:OSCHINA 博客文章版权属于作者,受法律保护。未经作者同意不得转载。 注意:下载时需要SVN客户端!

  • 问题内容: 我们有一个spring 3应用程序,该应用程序仍然使用不推荐使用的持久性,并且想要迁移到更现代的JPA 。 是否可以在迁移过程中同时使用两个API(可能甚至在一个事务中同时使用两个API),以便我们可以分步进行迁移? 还是我们必须大爆炸? 问题答案: 当然可以,为什么不呢。 最简单的方法是删除和配置,并分别用和替换它。 然后,以获得附加的,它公开的基本的。 这样,两种技术应该和平共处。

  • 在这个线程中,建议OP使用而不是来获取Linux中的共享内存。我访问了这个页面和这个页面以获得一些文档,但是第二个页面给出了一个关于的模糊示例。 作为一个新手,并且需要在两个进程之间共享一些信息(文本形式),我应该使用方法还是?为什么呢?

  • DaoCloud 和 Docker 是什么关系?且听我们的用户 Adrian Zhang 给您娓娓道来。以下内容由 Adrian 投稿,DaoCloud 获授权刊登。 作者:Adrian Zhang 一天,乔布斯走进了拉里.凯尼恩(Larry Kenyan)的办公隔间,他是负责麦金塔电脑操作系统的工程师,抱怨说开机启动时间太长了。凯尼恩开始解释,但乔布斯打断了他。他问道:「如果能救人一命的话,你愿