首页 > 学院 > 开发设计 > 正文

如何实现用jacob来调用word的宏

2019-11-18 11:58:20
字体:
来源:转载
供稿:网友

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

发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表