`
lgl669
  • 浏览: 169151 次
  • 性别: Icon_minigender_1
  • 来自: 上海
社区版块
存档分类
最新评论

Java调用com组件操作word使用总结

    博客分类:
  • java
阅读更多

 

一、准备工作

  先了解一下概念,JACOB 就是 JAVA-COM Bridge的缩写,提供自动化的访问com的功能,也是通过JNI功能访问windows平台下的com组件或者win32系统库的。这是一个开始于 1999年的开源项目的成果,有很多使用者对该项目进行了修改,做出了自己的贡献。

  Jacob下载 地址:http://sourceforge.net/project/showfiles.php?group_id=109543&package_id=118368

  我在这里下载 了Jacob1.14.3和jacob1.9的版本两个版本

  这里下载 的是目前最新的Jacob1.14.3的Release版。

  另外java操作word方式还有(个人认为通过jacob最好,自己可以扩展,网上除poi之外几乎全是java-com技术实现的):

  (1):Apache POI - Java API To Access Microsoft Format Files(http://poi.apache.org/ );对word处理不够强处理Excel功能可以,但是全是通过java完成的,不需 要com组件支持;

  (2):java2word 是一个在java程序中调用 MS Office Word 文档的组件(类库)。该组件提供了一组简单的接口,以便java程序调用他的服务操作Word 文档。(好象也是用的java-com技术);

  (3)web开发语言操作word的功能最好还是用第三方的控件, 看看这个SOAOFFICE,还可以使用js 写VBA呢 http://www.kehansoft.com/soaoffice/doclist.asp

  二、安装Jacob

  Jacob的安装非常的简单,我们解开下载的jacob_1.9.zip,在文件夹中找到jacob.dll和jacob.jar两个文件,如果是 Jacob1.14.3则是jacob-1.14.3-x86.dll(32位,机和jacob-1.14.3-x64.dll(64位)和 jacob.jar两个文件。Jacob.dll直接放到系统的system32文件夹下就行了,连注册都不用的(或者拷贝到jdk或者jre的bin目 录下也行,当前测试 文件所在的目录也行,就是只要在java.library.path中就可以)。而jacob.jar设置到classpath中去就 可以了,或者在IDE开发环境的工程中设置扩展库也一样的,我是这样使用的将jacob-1.14.3-x86.dll或复制 到%Tomcat5%\bin目录下将jacob.jar复制到%Tomcot5%\Share\lib目录下,我使用过程中感觉放到这里是一个最终解决 办法,当你放哪都有问题的时候。我这样用之后再没有出过因为系统不一样出现的各种各样的问题,当然你作的是web的项目。

  注意使用jacob一写要安装word,我装的word2003,如果是操作word2007就不用jacob了(好像这方面的API)。

  对jacob.dll几种配置方法 (网上看到):

  2008-07-31 11:59:49

  1、把jacob.dll文件,复制到 windows\system32 目录下。(注:我用的时候这个方法不能运行)

  2、 把jacob.dll放入 Java \jdk1.5.0_06\jre\bin目录下.把jacob.jar放入 Java\jdk1.5.0_0\jre\lib\ext目录下.可以正常运行。

  3、把jacob.dll放入 \glc\src目录下.把jacob.jar放入WEB-INF\lib目录下,也是可以正常运行。

  三、使用(以下是我改写的一个word操作类,希望有兴趣的朋友完善,记得发给我一份)

  //注意java操作word关键是定位操作对象;

  import com.jacob.activeX.ActiveXComponent;

  import com.jacob.com.Dispatch;

  import com.jacob.com.Variant;

  /**

  * jacob操作MSword类

  * @author

  */

  public class WordBean {

  // word文档

  private Dispatch doc;

  // word运行程序对象

  private ActiveXComponent word;

  // 所有word文档集合

  private Dispatch documents;

  // 选定的范围或插入点

  private Dispatch selection;

  private boolean saveOnExit = true;

  public WordBean()throws Exception{

  if (word == null) {

  word = new ActiveXComponent("Word.Application");

  word.setProperty("Visible", new Variant(false)); //不可见打开word

  word.setProperty("AutomationSecurity", new Variant(3)); //禁用宏

  }

  if (documents == null)

  documents = word.getProperty("Documents").toDispatch();

  }

  /**

  * 设置退出时参数

  *

  * @param saveOnExit

  * boolean true-退出时保存文件,false-退出时不保存文件

  */

  public void setSaveOnExit(boolean saveOnExit) {

  this.saveOnExit = saveOnExit;

  }

  /**

  * 创建一个新的word文档

  *

  */

  public void createNewDocument() {

  doc = Dispatch.call(documents, "Add").toDispatch();

  selection = Dispatch.get(word, "Selection").toDispatch();

  }

  /**

  * 打开一个已存在的文档

  *

  * @param docPath

  */

  public void openDocument(String docPath) {

  closeDocument();

  doc = Dispatch.call(documents, "Open", docPath).toDispatch();

  selection = Dispatch.get(word, "Selection").toDispatch();

  }

 

 /**

  *只读 打开一个保护文档,

  * @param docPath-文件全名

  * @param pwd-密码

  */

  public void openDocumentOnlyRead(String docPath, String pwd)throws Exception {

  closeDocument();

  // doc = Dispatch.invoke(documents, "Open", Dispatch.Method,

  // new Object[]{docPath, new Variant(false), new Variant(true), new Variant(true), pwd},

  // new int[1]).toDispatch();//打开word文件

  doc = Dispatch.callN(documents, "Open", new Object[]{docPath, new Variant(false),

  new Variant(true), new Variant(true), pwd, "", new Variant(false)}).toDispatch();

  selection = Dispatch.get(word, "Selection").toDispatch();

  }

  public void openDocument(String docPath, String pwd)throws Exception {

  closeDocument();

  doc = Dispatch.callN(documents, "Open", new Object[]{docPath, new Variant(false),

  new Variant(false), new Variant(true), pwd}).toDispatch();

  selection = Dispatch.get(word, "Selection").toDispatch();

  }

  /**

  * 把选定的内容或插入点向上移动

  *

  * @param pos

  * 移动的距离

  */

  public void moveUp(int pos) {

  if (selection == null)

  selection = Dispatch.get(word, "Selection").toDispatch();

  for (int i = 0; i < pos; i++)

  Dispatch.call(selection, "MoveUp");

  }

  /**

  * 把选定的内容或者插入点向下移动

  *

  * @param pos

  * 移动的距离

  */

  public void moveDown(int pos) {

  if (selection == null)

  selection = Dispatch.get(word, "Selection").toDispatch();

  for (int i = 0; i < pos; i++)

  Dispatch.call(selection, "MoveDown");

  }

  /**

  * 把选定的内容或者插入点向左移动

  *

  * @param pos

  * 移动的距离

  */

  public void moveLeft(int pos) {

  if (selection == null)

  selection = Dispatch.get(word, "Selection").toDispatch();

  for (int i = 0; i < pos; i++) {

  Dispatch.call(selection, "MoveLeft");

  }

  }

  /**

  * 把选定的内容或者插入点向右移动

  *

  * @param pos

  * 移动的距离

  */

  public void moveRight(int pos) {

  if (selection == null)

  selection = Dispatch.get(word, "Selection").toDispatch();

  for (int i = 0; i < pos; i++)

  Dispatch.call(selection, "MoveRight");

  }

  /**

  * 把插入点移动到文件首位置

  *

  */

  public void moveStart() {

  if (selection == null)

  selection = Dispatch.get(word, "Selection").toDispatch();

  Dispatch.call(selection, "HomeKey", new Variant(6));

  }

 

/**

  * 从选定内容或插入点开始查找文本

  *

  * @param toFindText

  * 要查找的文本

  * @return boolean true-查找到并选中该文本,false-未查找到文本

  */

  @SuppressWarnings("static-access")

  public boolean find(String toFindText) {

  if (toFindText == null || toFindText.equals(""))

  return false;

  // 从selection所在位置开始查询

  Dispatch find = word.call(selection, "Find").toDispatch();

  // 设置要查找的内容

  Dispatch.put(find, "Text", toFindText);

  // 向前查找

  Dispatch.put(find, "Forward", "True");

  // 设置格式

  Dispatch.put(find, "Format", "True");

  // 大小写匹配

  Dispatch.put(find, "MatchCase", "True");

  // 全字匹配

  Dispatch.put(find, "MatchWholeWord", "True");

  // 查找并选中

  return Dispatch.call(find, "Execute").getBoolean();

  }

  /**

  * 把选定选定内容设定为替换文本

  *

  * @param toFindText

  * 查找字符串

  * @param newText

  * 要替换的内容

  * @return

  */

  public boolean replaceText(String toFindText, String newText) {

  if (!find(toFindText))

  return false;

  Dispatch.put(selection, "Text", newText);

  return true;

  }

  /**

  * 全局替换文本

  *

  * @param toFindText

  * 查找字符串

  * @param newText

  * 要替换的内容

  */

  public void replaceAllText(String toFindText, String newText) {

  while (find(toFindText)) {

  Dispatch.put(selection, "Text", newText);

  Dispatch.call(selection, "MoveRight");

  }

  }

  /**

  * 在当前插入点插入字符串

  *

  * @param newText

  * 要插入的新字符串

  */

  public void insertText(String newText) {

  Dispatch.put(selection, "Text", newText);

  }

  /**

  *

  * @param toFindText

  * 要查找的字符串

  * @param imagePath

  * 图片路径

  * @return

  */

  public boolean replaceImage(String toFindText, String imagePath) {

  if (!find(toFindText))

  return false;

  Dispatch.call(Dispatch.get(selection, "InLineShapes").toDispatch(),

  "AddPicture", imagePath);

  return true;

  }

 

/**

  * 全局替换图片

  *

  * @param toFindText

  * 查找字符串

  * @param imagePath

  * 图片路径

  */

  public void replaceAllImage(String toFindText, String imagePath) {

  while (find(toFindText)) {

  Dispatch.call(Dispatch.get(selection, "InLineShapes").toDispatch(),

  "AddPicture", imagePath);

  Dispatch.call(selection, "MoveRight");

  }

  }

  /**

  * 在当前插入点插入图片

  *

  * @param imagePath

  * 图片路径

  */

  public void insertImage(String imagePath) {

  Dispatch.call(Dispatch.get(selection, "InLineShapes").toDispatch(),

  "AddPicture", imagePath);

  }

  /**

  * 合并单元格

  *

  * @param tableIndex

  * @param fstCellRowIdx

  * @param fstCellColIdx

  * @param secCellRowIdx

  * @param secCellColIdx

  */

  public void mergeCell(int tableIndex, int fstCellRowIdx, int fstCellColIdx,

  int secCellRowIdx, int secCellColIdx) {

  // 所有表格

  Dispatch tables = Dispatch.get(doc, "Tables").toDispatch();

  // 要填充的表格

  Dispatch table = Dispatch.call(tables, "Item", new Variant(tableIndex))

  .toDispatch();

  Dispatch fstCell = Dispatch.call(table, "Cell",

  new Variant(fstCellRowIdx), new Variant(fstCellColIdx))

  .toDispatch();

  Dispatch secCell = Dispatch.call(table, "Cell",

  new Variant(secCellRowIdx), new Variant(secCellColIdx))

  .toDispatch();

  Dispatch.call(fstCell, "Merge", secCell);

  }

  /**

  * 在指定的单元格里填写数据

  *

  * @param tableIndex

  * @param cellRowIdx

  * @param cellColIdx

  * @param txt

  */

  public void putTxtToCell(int tableIndex, int cellRowIdx, int cellColIdx,

  String txt) {

  // 所有表格

  Dispatch tables = Dispatch.get(doc, "Tables").toDispatch();

  // 要填充的表格

  Dispatch table = Dispatch.call(tables, "Item", new Variant(tableIndex))

  .toDispatch();

  Dispatch cell = Dispatch.call(table, "Cell", new Variant(cellRowIdx),

  new Variant(cellColIdx)).toDispatch();

  Dispatch.call(cell, "Select");

  Dispatch.put(selection, "Text", txt);

  }

  /**

  * 获得指定的单元格里数据

  *

  * @param tableIndex

  * @param cellRowIdx

  * @param cellColIdx

  * @return

  */

  public String getTxtFromCell(int tableIndex, int cellRowIdx, int cellColIdx) {

  // 所有表格

  Dispatch tables = Dispatch.get(doc, "Tables").toDispatch();

  // 要填充的表格

  Dispatch table = Dispatch.call(tables, "Item", new Variant(tableIndex))

  .toDispatch();

  Dispatch cell = Dispatch.call(table, "Cell", new Variant(cellRowIdx),

  new Variant(cellColIdx)).toDispatch();

  Dispatch.call(cell, "Select");

  String ret = "";

  ret = Dispatch.get(selection, "Text").toString();

  ret = ret.substring(0, ret.length()-1); //去掉最后的回车符;

  return ret;

  }

 

 /**

  * 在当前文档拷贝剪贴板数据

  * @param pos

  */

  public void pasteExcelSheet(String pos) {

  moveStart();

  if (this.find(pos)) {

  Dispatch textRange = Dispatch.get(selection, "Range").toDispatch();

  Dispatch.call(textRange, "Paste");

  }

  }

  /**

  * 在当前文档指定的位置拷贝表格

  *

  * @param pos

  * 当前文档指定的位置

  * @param tableIndex

  * 被拷贝的表格在word文档中所处的位置

  */

  public void copyTable(String pos, int tableIndex) {

  // 所有表格

  Dispatch tables = Dispatch.get(doc, "Tables").toDispatch();

  // 要填充的表格

  Dispatch table = Dispatch.call(tables, "Item", new Variant(tableIndex))

  .toDispatch();

  Dispatch range = Dispatch.get(table, "Range").toDispatch();

  Dispatch.call(range, "Copy");

  if (this.find(pos)) {

  Dispatch textRange = Dispatch.get(selection, "Range").toDispatch();

  Dispatch.call(textRange, "Paste");

  }

  }

  /**

  * 在当前文档指定的位置拷贝来自另一个文档中的表格

  *

  * @param anotherDocPath

  * 另一个文档的磁盘路径

  * @param tableIndex

  * 被拷贝的表格在另一格文档中的位置

  * @param pos

  * 当前文档指定的位置

  */

  public void copyTableFromAnotherDoc(String anotherDocPath, int tableIndex,

  String pos) {

  Dispatch doc2 = null;

  try {

  doc2 = Dispatch.call(documents, "Open", anotherDocPath)

  .toDispatch();

  // 所有表格

  Dispatch tables = Dispatch.get(doc2, "Tables").toDispatch();

  // 要填充的表格

  Dispatch table = Dispatch.call(tables, "Item",

  new Variant(tableIndex)).toDispatch();

  Dispatch range = Dispatch.get(table, "Range").toDispatch();

  Dispatch.call(range, "Copy");

  if (this.find(pos)) {

  Dispatch textRange = Dispatch.get(selection, "Range")

  .toDispatch();

  Dispatch.call(textRange, "Paste");

  }

  } catch (Exception e) {

  e.printStackTrace();

  } finally {

  if (doc2 != null) {

  Dispatch.call(doc2, "Close", new Variant(saveOnExit));

  doc2 = null;

  }

  }

  }

分享到:
评论

相关推荐

    java调用com组件操作word使用总结

    java调用com组件操作word使用总结(jacob)

    java调用word组件

    java2word 是一个在java程序中调用 MS Office Word 文档的组件(类库)。该组件提供了一组简单的接口,以便java程序调用他的服务操作Word 文档。

    操作com组件的可以java直接调用vb的dll

    操作com组件的可以java直接调用vb的dll 或者直接操作word excel等程序

    java调用dll/com组件word excel使用jawin架包

    NULL 博文链接:https://zhoutiea.iteye.com/blog/626373

    如何利用Java-JACOB操作WORD文档

    使用JACOB允许任何JVM访问COM对象,从而使JAVA应用程序能够调用COM对象。如果你要对 MS Word、Excel 进行处理,JACOB 是一个好的选择。JACOB目前已经成为sourceforge...

    java实现word在线编辑及流转

    java开发web办公系统,调用PageOffice组件实现word在线编辑及流转

    实现java对word文档的操作

    该组件提供了一组简单的接口,以便java程序调用他的服务操作Word 文档。 这些服务包括: 打开文档、新建文档、 查找文字、替换文字, 插入文字、插入图片、插入表格, 在书签处插入文字、插入图片、插入表格等。 ...

    java word转pdf

    调用OPEN office组件实现java程序的word转pdf

    Java编程实现调用com操作Word方法实例代码

    主要介绍了Java编程实现调用com操作Word方法实例代码,代码注释很详细,在这里分给大家,需要的朋友可以参考下。

    java将Word转换成PDF插件

    JACOB 一个 Java-COM 中间件。通过这个组件你可以在 Java 应用程序中调用 COM 组件和 Win32 程序库。

    word转换为pdf

    1、Java2Word是操作word的工具类,使用Jacod开源包调用word的com组件。 2、WordToPdf是使用Adobe Reader虚拟打印机实现打印word。 3、使用jacob技术调用2007自带的word转pdf工具,WordToPdfOffice2007是使用office...

    巧用Java程序把Word转换成Html文件

    Jacob是Java和Windows下的Com桥,通过它我们可以在Java程序中调用COM组件。如果你的JDK是1.4,那你需要下载Jacob1.9的jni库才能正常运行,早期版本在JDK1.4下有些问题。

    java开源包1

    JCom (Java-COM Bridge) 可以让 Java 程序轻松访问 Windows 平台上的 COM 组件。 JARP JARP是为petri 网提供的一个Java编辑器,基于ARP分析器。可以将网络图导出为 GIF, JPEG, PNG, PPM, ARP and PNML (XML based)...

    JAVA上百实例源码以及开源项目

     Java二进制IO类与文件复制操作实例,好像是一本书的例子,源代码有的是独立运行的,与同目录下的其它代码文件互不联系,这些代码面向初级、中级Java程序员。 Java访问权限控制源代码 1个目标文件 摘要:Java源码,...

    JACOB jar 下载 ,方便java 操作office 软件

    com一般表现为dll或exe等二进制文件,像我们呆会会用到的jacob.dll文件这里说说为什么我们用java去操纵office(如:word)要使用com,而不直接 使用java去做? 首先,我们清楚office是建立在windows平台之上的,本身是...

    JAVA上百实例源码以及开源项目源代码

     Java二进制IO类与文件复制操作实例,好像是一本书的例子,源代码有的是独立运行的,与同目录下的其它代码文件互不联系,这些代码面向初级、中级Java程序员。 Java访问权限控制源代码 1个目标文件 摘要:Java源码,...

    java开源包8

    JCom (Java-COM Bridge) 可以让 Java 程序轻松访问 Windows 平台上的 COM 组件。 JARP JARP是为petri 网提供的一个Java编辑器,基于ARP分析器。可以将网络图导出为 GIF, JPEG, PNG, PPM, ARP and PNML (XML based)...

    java开源包101

    JCom (Java-COM Bridge) 可以让 Java 程序轻松访问 Windows 平台上的 COM 组件。 JARP JARP是为petri 网提供的一个Java编辑器,基于ARP分析器。可以将网络图导出为 GIF, JPEG, PNG, PPM, ARP and PNML (XML based)...

    java开源包11

    JCom (Java-COM Bridge) 可以让 Java 程序轻松访问 Windows 平台上的 COM 组件。 JARP JARP是为petri 网提供的一个Java编辑器,基于ARP分析器。可以将网络图导出为 GIF, JPEG, PNG, PPM, ARP and PNML (XML based)...

    java开源包6

    JCom (Java-COM Bridge) 可以让 Java 程序轻松访问 Windows 平台上的 COM 组件。 JARP JARP是为petri 网提供的一个Java编辑器,基于ARP分析器。可以将网络图导出为 GIF, JPEG, PNG, PPM, ARP and PNML (XML based)...

Global site tag (gtag.js) - Google Analytics