国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 學院 > 開發(fā)設計 > 正文

如何實現(xiàn)用jacob來調用word的宏

2019-11-18 11:58:20
字體:
來源:轉載
供稿:網(wǎng)友

  問題的提出
  
  如何用java調用Word.exe的宏和其他功能?
  
  poi和jacob似乎只能抽取doc文檔的內容,而我現(xiàn)在需要在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官方網(wǎng)站的原話,本人就不再多說了。jacob的實現(xiàn)有些像封裝了com功能的jni調用的集合及承載com對象的容器。jacob作者Dan Adler使用了c++編寫了一批程序庫實現(xiàn)對com的引用/承載/調用,然后使用java的jni技術調用這些程序庫,實現(xiàn)JAVA-COM Bridge。
  
  關于作者如何封裝的可以參考http://danadler.com/jacob/,其方法和類與微軟的javasdk文檔一致,有愛好的朋友可以look一下。
  
  VB實現(xiàn)
  
  查看使用vb開發(fā)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.Descr  
  這樣就能在vb中訪問word的macro。。
  
  這樣只要使用jacob寫一段代碼來實現(xiàn)vb代碼的java調用,就ok了。
  
  java實現(xiàn)
  
  繼續(xù)上面的,現(xiàn)在發(fā)布一下我使用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 Sub
PRivate 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 調用宏的參數(shù)數(shù)組  */  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();     //使用方法傳入的參數(shù)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方法。

發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
主站蜘蛛池模板: 大埔区| 浦北县| 盖州市| 邮箱| 麻城市| 福贡县| 泰顺县| 四川省| 烟台市| 治多县| 二手房| 南部县| 汉阴县| 湾仔区| 搜索| 仁化县| 仙桃市| 岳西县| 西昌市| 额尔古纳市| 长沙县| 敦煌市| 锡林郭勒盟| 黄大仙区| 宁安市| 潮州市| 宾川县| 收藏| 遂溪县| 灵璧县| 依兰县| 泾川县| 陆丰市| 六安市| 东丽区| 奉化市| 长丰县| 武冈市| 韩城市| 青冈县| 海安县|