从VBScript调用外部VBA

问题描述

| 我正在使用一个名为mathtype的程序从Word文档中提取一些方程式对象。我已经在VBA中编写了可以使用其API完美运行的代码,但是我必须将其转换为VBScript文件。我在Google各处搜索,但未找到有关如何(如果可能)从VBScript调用VBA库的任何解决方案。 VBScript看不到MathTypeSDK对象/函数。 如果不可能,如何将需要运行的宏封装在全局可用的word文件中,并从VBScript调用它? 编辑:知道了!不幸的是,以下方法虽然有用,但不适用于我的情况。我发现更近一些:将宏嵌入到全局文件中,然后通过Word Objects Run命令调用它。 objWord.Run \“ Normal.NewMacros.RunMain \”     

解决方法

        这是一种可能对您有用的方法。我测试了这个简单的例子。 文件“ Tester.docm”中的类“ clsTest”:
Public Sub Hello()
    MsgBox \"Hello\"
End Sub
类“ Instancing”标记为“ PublicNotCreatable”。 \“ Tester.docm \”中的模块:
Public Function GetClass() As clsTest
    Set GetClass = New clsTest
End Function
在您的vbscript中:
Dim fPath,fName

fPath = \"C:\\Documents and Settings\\twilliams\\Desktop\\\"
fName = \"Tester.docm\"

Dim wdApp,o

Set wdApp = CreateObject(\"word.application\")
wdApp.visible=true
wdapp.documents.open fPath & fName

Set o = wdApp.Run(\"GetClass\")
o.Hello

Set o=nothing
再次-我只测试了这个简单的示例:您必须根据情况调整并尝试一下。     ,        我想,Word-VBA不是用来创建可重用的库的(用于外部程序)。 但是,重用现有Word-VBA代码的一种方法是使用
/m<macroname>
命令行开关通过
WScript.Shell.Run
运行Word(有关详细信息,请参见http://support.microsoft.com/kb/210565/en-us)。这样做有一个限制,那就是每次您都需要调用特定的宏时,Word进程将再次启动并运行该宏,然后结束。意味着,如果只需要对特定任务执行一次Word.VBA调用,就可以,但是,如果您需要VBScript与VBA宏之间的大量进程间通信,则应该寻找其他解决方案。     

相关问答

错误1:Request method ‘DELETE‘ not supported 错误还原:...
错误1:启动docker镜像时报错:Error response from daemon:...
错误1:private field ‘xxx‘ is never assigned 按Alt...
报错如下,通过源不能下载,最后警告pip需升级版本 Requirem...