添加自定义宏插件后,如何将其自动添加到工具栏/功能区?

hun*_*ens 2 excel installation vba add-in

如何尽可能快速简单地添加自定义宏 XLAM 文件?

我有一个保存为 XLAM 文件的宏。我希望我工作的其他不精通 Excel 的人能够下载 XLAM 文件,像使用任何其他加载项(例如 Solver)一样添加它,并使其成为一个简单的万无一失的过程。

但是,目前它涉及添加它,然后转到文件 > 选项 > 自定义功能区 > 宏 > MyFancyMacroAddin。然后单击加载项,然后创建一个新选项卡和子组,我可以将加载项从左列移到右列。这是一个漫长且容易出错的过程。每当我添加 Solver 之类的东西时,它都会在添加后弹出我的工具栏中。但是,在执行自定义 XLAM 时,它似乎需要更多步骤。

任何投入将不胜感激。

adu*_*uid 5

Microsoft Excel 功能区

要在 Excel 中创建/编辑功能区,请使用自定义 UI 编辑器工具。以下是创建 XML 的一些来源:


安装 Excel VBA 加载项

我在 .bat 文件中使用XCOPY将我的 .xlam 文件安装到用户机器上。我将在网络共享上设置一个文件夹,例如S:\Addins\MyFancyMacroAddin,将 .xlam 和 .bat 文件放入其中。然后我将 .bat 文件的快捷方式分发给最终用户。它将文件从当前目录复制到他们机器上的XLSTART文件夹。

您可以单击下面的动画以更轻松地查看它。

例子:

例子

代码:

@ECHO OFF

REM |--------------------------------------------------------------------------------------------------------------------
REM | Purpose:  Generic Excel Addin Install
REM |--------------------------------------------------------------------------------------------------------------------


REM
REM     /E   = Copies directories and sub-directories, including empty ones. Same as /S /E. May be used to modify /T. 
REM     /D:m-d-y = Copies files changed on or after the specified date. 
REM        If no date is given, copies only those files whose source time is newer than the destination time. 
REM     /K   = Copies attributes. Normal Xcopy will reset read-only attributes. 
REM     /Q   = Does not display file names while copying. 
REM     /R   = Overwrites read-only files. 
REM     /Y   = Suppresses prompting to confirm you want to overwrite an existing destination file. 
REM

REM Copy the install directory and sub-directories
REM echo f | XCOPY ".\MyFancyMacroAddin.xlam" "%AppData%\Microsoft\AddIns\MyFancyMacroAddin.xlam" /E /K /Q /R /Y /D
    echo f | XCOPY ".\MyFancyMacroAddin.xlam" "%AppData%\Microsoft\Excel\XLSTART\MyFancyMacroAddin.xlam" /E /K /Q /R /Y /D
REM echo f | XCOPY ".\MyFancyMacroAddin.xlam" "%AppData%\Roaming\Microsoft\Excel\XLSTART\MyFancyMacroAddin.xlam" /E /K /Q /R /Y /D
Run Code Online (Sandbox Code Playgroud)