105

之前有人 这个问题,但每次接受的答案只是使用Application.MacroOptionsVBA6)(VBA7)提供功能描述的辞职,但此信息实际上并未显示为工具提示,因此无法解决我的问题。

目标

我们都希望能够通过任何方式(VBA、VSTO 或 COM 插件)定义自定义函数,并为用户提供函数及其参数的弹出/工具提示描述的好处,如出现在每个内置 Excel 函数中,无论是内联还是在公式栏中:

在此处输入图像描述

在此处输入图像描述

对此需求的广泛接受的答案是自定义功能是不可能的,但我希望挑战这种信念。

问题

目前,我见过的最好的方法是定义函数(通常使用上面的 MacroOptions 调用),以便在打开函数对话框(公式栏中的 fx 按钮)时,它们的函数和参数描述如下所示:

在此处输入图像描述

如您所见,这是一个具有许多参数的复杂函数。如果用户不知道这个“函数参数”对话框以及如何打开它,而只熟悉 Excel 的标准工具提示,他们将只会看到公式名称而没有其他帮助:

在此处输入图像描述

他们没有机会正确提供所需的参数。(不阅读文档,当然,没有用户这样做过。)

现在,高级用户可能知道,通过键入Ctrl++ ,他们将获得一个自动完成的函数参数列表,如下所示ShiftA

在此处输入图像描述

但是,当然,我们有与上面相同的问题,即标准的 excel 用户只会习惯于第一张图像的默认行为,并且可能永远不会学习该功能。

至此应该清楚为什么这还不够,我们想要每个内置函数都有什么——告诉用户如何使用该函数的内嵌工具提示。

挑逗

起初,我可能已经确信这根本不可能,除非使用本机 Excel 应用程序功能。加载项和 VBA 是可扩展性功能,并且此工具提示可能根本不可扩展。但该理论受到分析工具库插件的挑战。当然,它是在 Microsoft 中构建的,但 ANALYS32.xll 是一个独立的 XLL 插件,就像可以在 VB、C、C++ 和 C# 中生成的插件一样。果然,当这个 XLL 被加载到应用程序中时,它提供的函数具有与本机 excel 函数相同的工具提示:

在此处输入图像描述

当然,如果此信息以某种方式编码在此 XLL 文件中并传递到 Excel,是否有一种方法可以使用我们自己的加载项来复制它?我现在要开始自学一些关于反编译的知识,看看我是否可以对分析工具包中发生的任何事情进行逆向工程。

您如何提供帮助

我几乎可以肯定,我已经研究了有关此问题的所有公开信息。如果有人知道一些我不知道的东西可能对此有所帮助,请随时插话。我对逆向工程编译的 dll / xlls 非常不熟悉,所以如果有人想打开他们的 Analysis32.xll 本地副本和弄清楚它的自定义函数定义发生了什么,我将非常感激。否则,我将自己继续深入研究,直到我遇到所有死胡同并报告我的发现。

4

3 回答 3

42

我已经在 GitHub 上发布了一个概念验证项目作为Excel-DNA IntelliSense项目,实现了这一点。

使用 UI 自动化类来监视适当的 Excel 用户界面事件,在适当的时候显示一个表单。

该代码被包装为Excel-DNA插件,可在我的 Excel 2013 / Windows 8 机器上运行。我在另一种配置(Windows Server 2008 上的 64 位 Excel 2010)上进行了测试,但遇到了严重问题。

对于使用 Excel-DNA 属性定义的 C# 函数,如下所示:

[ExcelFunction(Description = 
    "A useful test function that adds two numbers, and returns the sum.")]
public static double AddThem(
    [ExcelArgument(Name = "Augend", 
                   Description = "is the first number, to which will be added")] 
    double v1,
    [ExcelArgument(Name = "Addend", 
                   Description = "is the second number that will be added")]     
    double v2)
{
    return v1 + v2;
}

我们得到了函数描述

功能说明

选择函数时,我们会得到参数帮助

参数帮助

看起来不错,但仍然很不稳定,只能在我的机器上运行,有时 Excel 会崩溃。不过,这可能是一个开始……


2014 年 5 月 9 日更新:

我已经取得了一些进展,弄清楚如何使论点有助于在旧版 Excel 和 Windows 下工作。但是,要使一切可靠,仍然需要做很多工作。任何想对此提供帮助的人都应该直接与我联系。


2016 年 6 月 18 日更新:

Excel UDF IntelliSense 对 Excel-DNA 加载项和 VBA 函数的支持现在正在测试中。有关说明,请参阅 GitHub 上的入门页面。

于 2013-07-07T23:56:24.640 回答
1

怎么样

  1. 在单元格的按键事件中捕获输入文本。像这样
  2. 检查文本是否与自定义函数匹配。
  3. 如果匹配,则显示标签或形状之类的内容以假装是工具提示。像这样

这可以接受吗?

它有点难看,但更容易。

于 2013-07-03T14:00:25.463 回答
-1

什么是 XLL?

XLL 是一个 DLL,它导出由 Excel 或 Excel 加载项管理器调用的多个过程。http://msdn.microsoft.com/en-us/library/office/bb687861.aspx

您如何开发 XLL?

带有 Visual C++ 的 Excel XLL SDK(或任何可以编译 DLL 并调用 SDK 过程的东西)

在哪里可以找到创建简单 XLL 的快速指南?

http://support.microsoft.com/kb/178474

我如何获得工具提示?

  1. 将您的函数实现为过程并将其导出
  2. 实施和导出程序 xlAutoOpen(void) - http://msdn.microsoft.com/en-us/library/office/bb687860.aspx
  3. xlAutoOpen 只需要调用 xlfRegister - http://msdn.microsoft.com/en-us/library/office/bb687900.aspx
  4. 对于工具提示,请特别注意:pxArgumentText, pxFunctionHelp, pxArgumentHelp1

遗憾的是,Analysis Toolpak 加载项也没有工具提示。

我的解决方案是错误的,但原始海报发布的信息有误。用 BINOMDIST 显示图片,如果他的链接清楚地表明这不是 ANALYS32.xll 的功能。

这意味着我试图解决一个不可能的问题。因为没有 XLL 可以满足发帖人的要求。如果您找到显示 XLL 工具提示的 Excel 版本,请告诉我。

关于发帖人提出的问题,试图模仿 XLL 行为,我确信我的回答与 ANALYS32.xll 所做的事情相关是最正确的。

于 2013-07-10T06:14:54.343 回答