站内搜索: 请输入搜索关键词

当前页面: 开发资料首页Java 专题如何使用jacob调用word的宏

如何使用jacob调用word的宏

摘要: 如何使用jacob调用word的宏
内容:
如何使用jacob调用word的宏

作者:cleverpig


版权声明:可以任意转载,转载时请务必以超链接形式标明文章原始出处和作者信息及本声明
原文地址:
http://www.matrix.org.cn/resource/article/43/43784_jacob.html
关键字:jacob,word,macro

问题的提出
如何用java调用word.exe的宏和其他功能?
poi和jacob好像只能抽取doc文档的内容,而我现在需要在java中利用word.exe的功能对doc文档进行加工,怎么办?这是一个matrix user:lingrings提出的问题。出于助人为乐的想法,自己便在google上查了一下,结果找到jacob。

jacob简介
JACOB is a JAVA-COM Bridge that allows you to call COM Automation components from Java。这是jacob官方网站的原话,本人就不再多说了。jacob的实现有些像封装了com功能的jni调用的集合及承载com对象的容器。jacob作者Dan Adler使用了c++编写了一批程序库实现对com的引用/承载/调用,然后使用java的jni技术调用这些程序库,实现JAVA-COM Bridge。
关于作者如何封装的可以参考http://danadler.com/jacob/,其方法和类与微软的javasdk文档一致,有兴趣的朋友可以look一下。

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 = ""

' 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 = Nothing

End Sub

Private Sub Command1_Click()
AutomateWord_OpenDoc
End 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牡担祷豾ordDoc
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方法。

参考资料:
jacob的官方文档:http://danadler.com/jacob/
微软的javasdk文档:http://f2.grp.yahoofs.com/v1/IIwuQ7rQyGCn-b-f4biL9n_xAwI_Oh3ieuWVDkLfPpaKBmRUjeUzAtCy5oljSMgzdV6OZMRRgrEwU1_RtIXS-h0h7O9W4RB7aUs48A/sdkdocs.zip.aa
http://f1.grp.yahoofs.com/v1/IIwuQzpwMrin-b-fbkPTfyGj7CXbfLb0h3lkvGL1GKMwCNpXXRKiKDwe3cx9aUVjO3KWdb7cPJWmqAXUCY_As6XeyLDKoGLYd7ez6g/sdkdocs.zip.ab
注意:这个压缩包是被分割的,在console中使用type sdkdocs.zip.aa sdkdocs.ab >sdkdocs.zip,进行合并。
Java, java, J2SE, j2se, J2EE, j2ee, J2ME, j2me, ejb, ejb3, JBOSS, jboss, spring, hibernate, jdo, struts, webwork, ajax, AJAX, mysql, MySQL, Oracle, Weblogic, Websphere, scjp, scjd
如何使用jacob调用word的宏

作者:cleverpig


版权声明:可以任意转载,转载时请务必以超链接形式标明文章原始出处和作者信息及本声明
原文地址:
http://www.matrix.org.cn/resource/article/43/43784_jacob.
↑返回目录
前一篇: java的30个学习目标
后一篇: 在你的企业级java应用中使用Drools