如何解决从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宏之间的大量进程间通信,则应该寻找其他解决方案。
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。