运行其他模块的VBA模块 [英] VBA module that runs other modules
问题描述
现在的想法是写一个运行其他模块的模块:
Sub moduleController()
运行Module1
运行Module2
End Sub
这给出错误:
运行时错误1004 - 无法运行宏macroname。此工作簿中的宏可能不可用,或者所有宏可能被禁用。
可能是什么解决方案?也许我的QueryTable加载问题有另一个解决方案?
只要所讨论的宏在同一个工作簿中,你验证名称是否存在,您可以通过名称而不是模块从任何其他模块中调用这些宏。
所以如果在Module1中有两个宏Macro1和Macro2以及Module2您有Macro3和Macro 4,然后在另一个宏中,您可以将它们全部称为:
Sub MasterMacro()
调用宏1
调用宏2
调用宏3
调用宏4
结束子
I'm programming in Microsoft VBA. At first I need to generate a QueryTable with the help of a macro (I've got the code for that) and after that with the help of macros I need to apply formulas that use the data in the QueryTable. The problem that I am facing is that the QueryTable appears only after the Sub, in which its code is, has finished working. That means that I cannot include the code that generates formulas in it, because there is no data for the formulas to be generated on.
The idea right now is to write a module that runs other modules:
Sub moduleController()
Run "Module1"
Run "Module2"
End Sub
This gives the error:
Run time error 1004 - cannot run the macro "macroname". The macro may not be available in this workbook or all macros may be disabled.
What could be the solution? Maybe there is another solution for my QueryTable loading problem?
As long as the macros in question are in the same workbook and you verify the names exist, you can call those macros from any other module by name, not by module.
So if in Module1 you had two macros Macro1 and Macro2 and in Module2 you had Macro3 and Macro 4, then in another macro you could call them all:
Sub MasterMacro()
Call Macro1
Call Macro2
Call Macro3
Call Macro4
End Sub
这篇关于运行其他模块的VBA模块的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!