网站首页

家园论坛

老版论坛

家园博客

业界新闻

技术文档

下载中心

速查中心

图片中心

硬件资讯
上一篇:用Java实现自动在数据库表中生成ID号 下一篇:Java 的JDBC 数据库连接池实现方法
如何使用jacob调用word的宏

来源:http://www.matrix.org.cn 作者:cleverpig  添加日期:2006-3-5 18:43:18 点击次数:

问题的提出
如何用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 SubPrivate

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方法。

 

 
设为首页 | 加入收藏 | 业务办理 | 友情链接 | 论坛版面 | 浙ICP备07502118号 |