|
問題的提出
如何用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 = "<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方法。 | |