【问题标题】:Launch the vba editor from excel by code通过代码从 excel 启动 vba 编辑器
【发布时间】:2012-09-23 23:38:21
【问题描述】:

Vsto-excel 项目中,我在特定模块中有一个 。 通过 C# 中的 code,我想启动显示给定 ma​​cro 的 VBA 编辑器。 我知道互操作概念,但我坚持启动 vba 编辑器并显示特定的宏。

【问题讨论】:

    标签: c# excel vba vsto


    【解决方案1】:

    您可以使用Application.Goto "MarcoName",它将在您指定的子/宏处打开 VBE。

    【讨论】:

    • 是的,效果很好,....但是如果我打开了 2 个工作簿并且两个工作簿都有同名的宏......那么活动工作簿的宏被称为??
    【解决方案2】:

    在打开的 Excel 工作表上的键盘快捷键 ALT + F11 默认打开 VBA 编辑器。 使用 excel interop 打开 excel 并使 excel 窗口可见。然后您可以将键盘快捷键从您的应用程序传递到 excel 窗口。

    如果您在winform应用程序上使用它,您可以使用sendkeys方法将键盘快捷键传递给excel窗口。 http://msdn.microsoft.com/en-us/library/system.windows.forms.sendkeys.send.aspx

    否则使用 sendmessage 方法来传递键盘快捷键。这是关于 sendmessage 用法的帖子,c# Sending keyboard commands to another window / process

    【讨论】:

      猜你喜欢
      • 1970-01-01
      • 2014-05-05
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 2012-12-05
      • 1970-01-01
      • 2023-03-27
      相关资源
      最近更新 更多