JACOB的call如何调用excel的宏
发布网友
发布时间:2022-05-17 15:32
我来回答
共1个回答
热心网友
时间:2023-10-27 04:15
虽然不懂,但还是把我找到的资料给你附上。
VB实现
查看使用vb开发office automation 的方法文档(http://www.microsoft.com/china/msdn/archives/technic/voices/office05042000.asp),和访问word中的macro的文档(http://support.microsoft.com/kb/q185167/),来获取如何通过vb访问word macro的方法:
例如marco定义如下:
Sub MyWordMacro(strPassedParam As String) MsgBox strPassedParam End Sub
而访问这个MyWordMacro宏的vb代码如下:
Sub AutomateWord_OpenDoc() Dim wrdApp As Object Dim wrdDoc As Object Dim strFileName As String Set wrdApp = CreateObject("Word.Application") On Error GoTo DocError ' Replace the following example string value with the path and ' file name of the template containing your macro. strFileName = "<Path and Filename of template>" ' Open the document and set a variable equal to a new blank ' document and its underlying template. Set wrdDoc = wrdApp.Documents.Add(strFileName) ' Run the macro. (Replace "MyWordMacro" with the name of your macro.) wrdDoc.MyWordMacro ("This is a test.") DocError: If Err.Number <> 0 Then Msgbox Err.Description ' Quit this instance of Word. wrdApp.Quit ' Clear variable memory. Set wrdApp = Nothing Set wrdDoc = Nothing End Sub
这样就能在vb中访问word的macro。。
这样只要使用jacob写一段代码来实现vb代码的java调用,就ok了。
java实现
继续上面的,现在发布一下我使用jacob调用word文件中的宏的代码。
首先说明一下,由于jacob是java与com之间的bridge,所以先描述一下使用vb调用上面的MyWordMacro宏的代码,这样可以与java代码作比较,更利于理解jacob的工作方式:
Sub AutomateWord_OpenDoc() Dim wrdApp As Object Dim wrdDoc As Object Dim strFileName As String Set wrdApp = CreateObject("Word.Application") On Error GoTo DocError '包含marco的word文件 strFileName = "c:\MacroTest.doc" '打开文件 Set wrdDoc = wrdApp.Documents.Open(strFileName) '运行宏 wrdDoc.MyWordMacro ("This is a test.")DocError: If Err.Number <> 0 Then MsgBox Err.Description '退出word wrdApp.Quit '清除内存 Set wrdApp = Nothing Set wrdDoc = NothingEnd SubPrivate Sub Command1_Click() AutomateWord_OpenDocEnd Sub
而对应的java代码如下:
package com.bjinfotech.practice.jacob;import com.jacob.com.*;import com.jacob.activeX.*;/** * 调用word文件中的宏 * @author 聪明的猪 * */public class Dispatch_MSWordMacro { /** * 打开word,调用word中的宏 * @param filePath word文件路径 * @param macroName 被调用的宏名字 * @param parameter 调用宏的参数数组 */ public void callWordMacro(String filePath,String macroName,Object parameter[]){ //建立ActiveX部件 ActiveXComponent wrdCom=new ActiveXComponent("Word.Application"); try{ //返回wrdCom.Documents的Dispatch Object wrdDocs=wrdCom.getProperty("Documents").toDispatch(); //调用wrdCom.Documents.Open方法打开指定的word文档,返回wordDoc Object wrdDoc=Dispatch.invoke(wrdDocs,"Open",Dispatch.Method,new Object[]{filePath},new int[1]).toDispatch(); //使用方法传入的参数parameter调用word文档中的MyWordMacro宏// Dispatch.call(wrdDoc,macroName,parameter); Dispatch.invoke(wrdDoc,macroName,Dispatch.Method,parameter,new int[1]); } catch(Exception ex){ ex.printStackTrace(); } finally{ //关闭word文件 wrdCom.invoke("Quit",new Variant[]{}); } } public static void main(String[] argv){ Dispatch_MSWordMacro d=new Dispatch_MSWordMacro(); d.callWordMacro("E:/eclipse3.1RC3/workspace/jacobPractice/src/com/bjinfotech/practice/jacob/MacroTest.doc","MyWordMacro",new String[]{"这是测试信息"}); }}
很明显,使用的方法与在vb等vs工具中相同,只不过在调用方法时使用了Dispatch,获得属性时使用了getProperty方法。追问这个例子我看过很多次了
可惜我不明白
准确的说是 没用明白
我需要的excel的宏 不是word的 而且该例子中的macro名称也没有指定
我不清楚他是怎么调用的宏。。。
我再等等看
谢谢你的回答
参考资料:http://www.bitscn.com/plus/view.php?aid=20768