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


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

    简单描述

        在此处输入简单摘要

    特别声明:使用java-com技术可以完成任何VBA可以完成的office文档操作;

     一、准备工作

       先了解一下概念,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%in目录下将jacob.jar复制到%Tomcot5%Sharelib目录下,我使用过程中感觉放到这里是一个最终解决 办法,当你放哪都有问题的时候。我这样用之后再没有出过因为系统不一样出现的各种各样的问题,当然你作的是web的项目。

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

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

    2008-07-31 11:59:49

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

    2、 把jacob.dll放入 Javajdk1.5.0_06jrein目录下.把jacob.jar放入 Javajdk1.5.0_0jrelibext  

        目录下.可以正常运行。

    3、把jacob.dll放入 glcsrc目录下.把jacob.jar放入WEB-INFlib目录下,也是可以正常运行。

    三、使用(以下是我改写的一个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;

    }

    }

    }

    /**

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

    *

    * @param anotherDocPath 另一个文档的磁盘路径

    * @param shapeIndex 被拷贝的图片在另一格文档中的位置

    * @param pos 当前文档指定的位置

    */

    public void copyImageFromAnotherDoc(String anotherDocPath, int shapeIndex,

    String pos) {

    Dispatch doc2 = null;

    try {

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

    .toDispatch();

    Dispatch shapes = Dispatch.get(doc2, "InLineShapes").toDispatch();

    Dispatch shape = Dispatch.call(shapes, "Item",

    new Variant(shapeIndex)).toDispatch();

    Dispatch imageRange = Dispatch.get(shape, "Range").toDispatch();

    Dispatch.call(imageRange, "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;

    }

    }

    }

    /**

    * 创建表格

    *

    * @param pos

    *            位置

    * @param cols

    *            列数

    * @param rows

    *            行数

    */

    public void createTable(String pos, int numCols, int numRows) {

    if (find(pos)) {

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

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

    @SuppressWarnings("unused")

    Dispatch newTable = Dispatch.call(tables, "Add", range,

    new Variant(numRows), new Variant(numCols)).toDispatch();

    Dispatch.call(selection, "MoveRight");

    } else {

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

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

    @SuppressWarnings("unused")

    Dispatch newTable = Dispatch.call(tables, "Add", range,

    new Variant(numRows), new Variant(numCols)).toDispatch();

    Dispatch.call(selection, "MoveRight");

    }

    }

    /**

    * 在指定行前面增加行

    *

    * @param tableIndex

    *            word文件中的第N张表(从1开始)

    * @param rowIndex

    *            指定行的序号(从1开始)

    */

    public void addTableRow(int tableIndex, int rowIndex) {

    // 所有表格

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

    // 要填充的表格

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

    .toDispatch();

    // 表格的所有行

    Dispatch rows = Dispatch.get(table, "Rows").toDispatch();

    Dispatch row = Dispatch.call(rows, "Item", new Variant(rowIndex))

    .toDispatch();

    Dispatch.call(rows, "Add", new Variant(row));

    }

    /**

    * 在第1行前增加一行

    *

    * @param tableIndex

    *  word文档中的第N张表(从1开始)

    */

    public void addFirstTableRow(int tableIndex) {

    // 所有表格

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

    // 要填充的表格

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

    .toDispatch();

    // 表格的所有行

    Dispatch rows = Dispatch.get(table, "Rows").toDispatch();

    Dispatch row = Dispatch.get(rows, "First").toDispatch();

    Dispatch.call(rows, "Add", new Variant(row));

    }

    /**

    * 在最后1行前增加一行

    *

    * @param tableIndex

    *            word文档中的第N张表(从1开始)

    */

    public void addLastTableRow(int tableIndex) {

    // 所有表格

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

    // 要填充的表格

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

    .toDispatch();

    // 表格的所有行

    Dispatch rows = Dispatch.get(table, "Rows").toDispatch();

    Dispatch row = Dispatch.get(rows, "Last").toDispatch();

    Dispatch.call(rows, "Add", new Variant(row));

    }

    /**

    * 增加一行

    *

    * @param tableIndex

    *            word文档中的第N张表(从1开始)

    */

    public void addRow(int tableIndex) {

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

    // 要填充的表格

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

    .toDispatch();

    // 表格的所有行

    Dispatch rows = Dispatch.get(table, "Rows").toDispatch();

    Dispatch.call(rows, "Add");

    }

    /**

    * 增加一列

    *

    * @param tableIndex

    *            word文档中的第N张表(从1开始)

    */

    public void addCol(int tableIndex) {

    // 所有表格

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

    // 要填充的表格

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

    .toDispatch();

    // 表格的所有行

    Dispatch cols = Dispatch.get(table, "Columns").toDispatch();

    Dispatch.call(cols, "Add").toDispatch();

    Dispatch.call(cols, "AutoFit");

    }

    /**

    * 在指定列前面增加表格的列

    *

    * @param tableIndex

    *            word文档中的第N张表(从1开始)

    * @param colIndex

    *            制定列的序号 (从1开始)

    */

    public void addTableCol(int tableIndex, int colIndex) {

    // 所有表格

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

    // 要填充的表格

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

    .toDispatch();

    // 表格的所有行

    Dispatch cols = Dispatch.get(table, "Columns").toDispatch();

    System.out.println(Dispatch.get(cols, "Count"));

    Dispatch col = Dispatch.call(cols, "Item", new Variant(colIndex))

    .toDispatch();

    // Dispatch col = Dispatch.get(cols, "First").toDispatch();

    Dispatch.call(cols, "Add", col).toDispatch();

    Dispatch.call(cols, "AutoFit");

    }

    /**

    * 在第1列前增加一列

    *

    * @param tableIndex

    *            word文档中的第N张表(从1开始)

    */

    public void addFirstTableCol(int tableIndex) {

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

    // 要填充的表格

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

    .toDispatch();

    // 表格的所有行

    Dispatch cols = Dispatch.get(table, "Columns").toDispatch();

    Dispatch col = Dispatch.get(cols, "First").toDispatch();

    Dispatch.call(cols, "Add", col).toDispatch();

    Dispatch.call(cols, "AutoFit");

    }

    /**

    * 在最后一列前增加一列

    *

    * @param tableIndex

    *            word文档中的第N张表(从1开始)

    */

    public void addLastTableCol(int tableIndex) {

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

    // 要填充的表格

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

    .toDispatch();

    // 表格的所有行

    Dispatch cols = Dispatch.get(table, "Columns").toDispatch();

    Dispatch col = Dispatch.get(cols, "Last").toDispatch();

    Dispatch.call(cols, "Add", col).toDispatch();

    Dispatch.call(cols, "AutoFit");

    }

    /**

    * 自动调整表格

    *

    */

    @SuppressWarnings("deprecation")

    public void autoFitTable() {

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

    int count = Dispatch.get(tables, "Count").toInt();

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

    Dispatch table = Dispatch.call(tables, "Item", new Variant(i + 1))

    .toDispatch();

    Dispatch cols = Dispatch.get(table, "Columns").toDispatch();

    Dispatch.call(cols, "AutoFit");

    }

    }

    /**

    * 调用word里的宏以调整表格的宽度,其中宏保存在document下

    *

    */

    @SuppressWarnings("deprecation")

    public void callWordMacro() {

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

    int count = Dispatch.get(tables, "Count").toInt();

    Variant vMacroName = new Variant("Normal.NewMacros.tableFit");

    @SuppressWarnings("unused")

    Variant vParam = new Variant("param1");

    @SuppressWarnings("unused")

    Variant para[] = new Variant[] { vMacroName };

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

    Dispatch table = Dispatch.call(tables, "Item", new Variant(i + 1))

    .toDispatch();

    Dispatch.call(table, "Select");

    Dispatch.call(word, "Run", "tableFitContent");

    }

    }

    /**

    * 设置当前选定内容的字体

    *

    * @param boldSize

    * @param italicSize

    * @param underLineSize

    *            下划线

    * @param colorSize

    *            字体颜色

    * @param size

    *            字体大小

    * @param name

    *            字体名称

    */

    public void setFont(boolean bold, boolean italic, boolean underLine,

    String colorSize, String size, String name) {

    Dispatch font = Dispatch.get(selection, "Font").toDispatch();

    Dispatch.put(font, "Name", new Variant(name));

    Dispatch.put(font, "Bold", new Variant(bold));

    Dispatch.put(font, "Italic", new Variant(italic));

    Dispatch.put(font, "Underline", new Variant(underLine));

    Dispatch.put(font, "Color", colorSize);

    Dispatch.put(font, "Size", size);

    }

    /**

    * 设置单元格被选中

    *

    * @param tableIndex

    * @param cellRowIdx

    * @param cellColIdx

    */

    public void setTableCellSelected(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");

    }

    /**

    * 设置选定单元格的垂直对起方式, 请使用setTableCellSelected选中一个单元格

    * @param align 0-顶端, 1-居中, 3-底端

    */

    public void setCellVerticalAlign(int verticalAlign){

    Dispatch cells = Dispatch.get(selection, "Cells").toDispatch();

    Dispatch.put(cells, "VerticalAlignment", new Variant(verticalAlign));

    }

    /**

    * 设置当前文档中所有表格水平居中方式及其它一些格式,用在将word文件转化为html中,针对申报表

    */

    @SuppressWarnings("deprecation")

    public void setApplyTableFormat(){

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

    int tabCount = Integer.valueOf(Dispatch.get(tables, "Count").toString()); //System.out.println(tabCount);

    System.out.println("*******************************************************");

    for(int i=1; i<=tabCount; i++){

    Dispatch table = Dispatch.call(tables, "Item", new Variant(i)).toDispatch();

    Dispatch rows = Dispatch.get(table, "Rows").toDispatch();

    if(i==1){

    Dispatch.put(rows, "Alignment", new Variant(2)); //1-居中,2-Right

    continue ;

    }

    Dispatch.put(rows, "Alignment", new Variant(1)); //1-居中

    Dispatch.call(table, "AutoFitBehavior", new Variant(1));//设置自动调整表格方式,1-根据窗口自动调整

    Dispatch.put(table, "PreferredWidthType", new Variant(1));

    Dispatch.put(table, "PreferredWidth", new Variant(700));

    System.out.println(Dispatch.get(rows, "HeightRule").toString());

    Dispatch.put(rows, "HeightRule", new Variant(1)); //0-自动wdRowHeightAuto,1-最小值wdRowHeightAtLeast, 2-固定wdRowHeightExactly

    Dispatch.put(rows, "Height", new Variant(0.04*28.35));

    //int oldAlign = Integer.valueOf(Dispatch.get(rows, "Alignment").toString());

    //System.out.println("Algin:" + oldAlign);

    }

    }

    /**

    * 设置段落格式

    *

    * @param alignment

    * 0-左对齐, 1-右对齐, 2-右对齐, 3-两端对齐, 4-分散对齐

    * @param lineSpaceingRule

    * @param lineUnitBefore

    * @param lineUnitAfter

    * @param characterUnitFirstLineIndent

    */

    public void setParagraphsProperties(int alignment, int lineSpaceingRule,

    int lineUnitBefore, int lineUnitAfter, int characterUnitFirstLineIndent){

    Dispatch paragraphs = Dispatch.get(selection, "Paragraphs").toDispatch();

    Dispatch.put(paragraphs, "Alignment", new Variant(alignment)); //对齐方式

    Dispatch.put(paragraphs, "LineSpacingRule", new Variant(lineSpaceingRule)); //行距

    Dispatch.put(paragraphs, "LineUnitBefore", new Variant(lineUnitBefore)); //段前

    Dispatch.put(paragraphs, "LineUnitAfter", new Variant(lineUnitAfter)); //段后

    Dispatch.put(paragraphs, "CharacterUnitFirstLineIndent",

    new Variant(characterUnitFirstLineIndent)); //首行缩进字符数

    }

    /**

    * 打印当前段落格式, 使用前,请先选中段落

    */

    public void getParagraphsProperties(){

    Dispatch paragraphs = Dispatch.get(selection, "Paragraphs").toDispatch();

    String val = Dispatch.get(paragraphs, "LineSpacingRule").toString(); //行距

    System.out.println("行距:" + val);

    val = Dispatch.get(paragraphs, "Alignment").toString(); //对齐方式

    System.out.println("对齐方式:" + val); //0-左对齐, 1-右对齐, 2-右对齐, 3-两端对齐, 4-分散对齐

    val = Dispatch.get(paragraphs, "LineUnitBefore").toString(); //段前行数

    System.out.println("段前行数:" + val);

    val = Dispatch.get(paragraphs, "LineUnitAfter").toString(); //段后行数

    System.out.println("段后行数:" + val);

    val = Dispatch.get(paragraphs, "FirstLineIndent").toString(); //首行缩进

    System.out.println("首行缩进:" + val);

    val = Dispatch.get(paragraphs, "CharacterUnitFirstLineIndent").toString(); //首行缩进字符数

    System.out.println("首行缩进字符数:" + val);

    }

    /**

    * 文件保存或另存为

    *

    * @param savePath

    *            保存或另存为路径

    */

    public void save(String savePath) {

    Dispatch.call(Dispatch.call(word, "WordBasic").getDispatch(),

    "FileSaveAs", savePath);

    }

    /**

    * 文件保存为html格式

    *

    * @param savePath

    * @param htmlPath

    */

    public void saveAsHtml(String htmlPath){

    Dispatch.invoke(doc,"SaveAs", Dispatch.Method,

    new Object[]{htmlPath, new Variant(8)}, new int[1]);

    }

    /**

    * 关闭文档

    *@param val 0不保存修改 -1 保存修改 -2 提示是否保存修改

    */

    public void closeDocument(int val) {

    Dispatch.call(doc, "Close", new Variant(val));

    doc = null;

    }

    /**

    * 关闭当前word文档

    *

    */

    public void closeDocument() {

    if (doc != null) {

    Dispatch.call(doc, "Save");

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

    doc = null;

    }

    }

    public void closeDocumentWithoutSave(){

    if (doc != null) {

    Dispatch.call(doc, "Close", new Variant(false));

    doc = null;

    }

    }

    /**

    * 关闭全部应用

    *

    */

    public void close() {

    //closeDocument();

    if (word != null) {

    Dispatch.call(word, "Quit");

    word = null;

    }

    selection = null;

    documents = null;

    }

    /**

    * 打印当前word文档

    *

    */

    public void printFile() {

    if (doc != null) {

    Dispatch.call(doc, "PrintOut");

    }

    }

    /**

    * 保护当前档,如果不存在, 使用expression.Protect(Type, NoReset, Password)

    *

    * @param pwd

    * WdProtectionType 可以是下列 WdProtectionType 常量之一:

    * 1-wdAllowOnlyComments, 2-wdAllowOnlyFormFields, 0-wdAllowOnlyRevisions,

    * -1-wdNoProtection, 3-wdAllowOnlyReading

    *

    */

    public void protectedWord(String pwd){

    String protectionType = Dispatch.get(doc, "ProtectionType").toString();

    if(protectionType.equals("-1")){

    Dispatch.call(doc, "Protect", new Variant(3), new Variant(true), pwd);

    }

    }

    /**

    * 解除文档保护,如果存在

    * @param pwd

    * WdProtectionType 常量之一(Long 类型,只读):

    * 1-wdAllowOnlyComments,2-wdAllowOnlyFormFields、

    * 0-wdAllowOnlyRevisions,-1-wdNoProtection, 3-wdAllowOnlyReading

    *

    */

    public void unProtectedWord(String pwd){

    String protectionType = Dispatch.get(doc, "ProtectionType").toString();

    if(protectionType.equals("3")){

    Dispatch.call(doc, "Unprotect", pwd);

    }

    }

    /**

    * 设置word文档安全级别

    * @param value

    * 1-msoAutomationSecurityByUI  使用“安全”对话框指定的安全设置。

    * 2-msoAutomationSecurityForceDisable  在程序打开的所有文件中禁用所有宏,而不显示任何安全提醒。

    * 3-msoAutomationSecurityLow  启用所有宏,这是启动应用程序时的默认值。

    */

    public void setAutomationSecurity(int value){

    word.setProperty("AutomationSecurity", new Variant(value));

    }

    /**

    * 读取文档中第paragraphsIndex段文字的内容;

    * @param paragraphsIndex

    * @return

    */

    public String getParagraphs(int paragraphsIndex){

    String ret = "";

    Dispatch paragraphs = Dispatch.get(doc, "Paragraphs").toDispatch(); // 所有段落

    int paragraphCount = Dispatch.get(paragraphs, "Count").getInt(); // 一共的段落数

    Dispatch paragraph = null;

    Dispatch range = null;

    if(paragraphCount > paragraphsIndex && 0 < paragraphsIndex){

    paragraph = Dispatch.call(paragraphs, "Item", new Variant(paragraphsIndex)).toDispatch();

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

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

    }

    return ret;

    }

    public static void main(String[] args)throws Exception{

    WordBean word = new WordBean();

    word.createNewDocument();

    word.createTable("", 5, 5);

    word.mergeCell(1, 1, 1, 1, 5);

    word.mergeCell(1, 2, 1, 2, 5);

    word.mergeCell(1, 3, 1, 3, 5);

    word.putTxtToCell(1,1,1,"主题");

    word.putTxtToCell(1,2,1,"时间");

    word.putTxtToCell(1,3,1,"人员");

    word.putTxtToCell(1,4,2,"说话了");

    word.save("c:\jacobTest.doc");

    System.out.print("请打开c:\jacobTest.doc查看是否有写word成功!");

    word.close();

    }

    }

    四.使用错误分析:

    1.由于应用程序配置不正确,不能启用dll文件;

    解决:版本不对,换另一个版本试一下.

    2. ERROR [http-8080-Processor25] - Servlet.service() for servlet FileUploaded threw exception

        java.lang.UnsatisfiedLinkError: no jacob-1.14.3-x86 in java.library.path

        at java.lang.ClassLoader.loadLibrary(Unknown Source)

        at java.lang.Runtime.loadLibrary0(Unknown Source)

        at java.lang.System.loadLibrary(Unknown Source)

    将dll文件复制到tomcatin目录下重新启动tomcat5.5

    3.使用过程中(将项目发布到Tomcat5下运行时)提示

    java.lang.UnsatisfiedLinkError:

    Native Library D:Program FilesApache Software FoundationTomcat 5.5injacob-1.14.3-x86.dll

    already loaded in another classloader

    解决:将%Tomcat 5.5%webappsXXXXWEB-INFlib下的jacob.jar包剪切到%Tomcat 5.5%sharedlib目录下(或删除).

    五.自己改写WordBean类:

    1.改写前你要知道VBA,熟悉怎样用VBA操作word;

    2.将VBA操作改到java代码;要知道com.jacob.com.Dispatch可容纳任何VBA中的集合对象;

    如:Dispatch paragraphs = Dispatch.get(doc, "Paragraphs").toDispatch(); // 将Paragraphs 集合对象赋给Dispatch对象;

    3.使用VBA对象属性:

    如:int paragraphCount = Dispatch.get(paragraphs, "Count").getInt(); //调用Dispatch.get()方法获取Paragraphs 集合对象的Count属性;

    4.调用VBA对象方法:

    在VBA帮助中我们找到Document 对象Close方法是这样声明的:

    expression.Close(SaveChanges, OriginalFormat, RouteDocument)

    expression   必需。该表达式返回以上的一个对象。

    SaveChanges  Variant 类型,可选。指定保存文档的操作。可以是下列 WdSaveOptions 常量之一:wdDoNotSaveChanges、wdPromptToSaveChanges 或 wdSaveChanges。

    OriginalFormat  Variant 类型,可选。指定保存文档的格式。可以是下列 WdOriginalFormat 常量之一:wdOriginalDocumentFormat、wdPromptUser 或 wdWordDocument。

    RouteDocument  Variant 类型,可选。如果该属性值为 True,则将文档发送给下一个收件人。如果文档没有附加传送名单,则忽略该参数。

    因些我们可在WordBean添加一个这样的方法关闭文档:

    public void closeDocument(int val) {

    Dispatch doc = Dispatch.call(documents, "Open", docPath).toDispatch();  //doc是Document对象,调用

    Dispatch.call(doc, "Close", new Variant(val));  // val 0不保存修改 -1 保存修改 -2 提示是否保存修改,对应VBA中Document 对象Close方法的SaveChanges参数

    doc = null;

    }

    你会注意到Dispatch类重载了很多call方法,这与VBA中方法基本相似有很多参数是缺省的:

    你可还会注意到Dispatch还有个invoke方法其实它和call差不多也是调用VBA对象方法的,只参数的形式不同(我目前这样认为)

    Dispatch还有很多方法调用都是为配合调用VBA对象的方法,我还没有时间深入的看,等都明白再补上这部分说明;

    参考(自己Gooogle一下):

    JAVA 深度控制 WORD;

    Aspose.Words for Java 发布-操作word的工具

    用Java操作Office 2007(http://blog.163.com/peigen_peigen/blog/static/2704780200863082444566/)

    Java/Office2007 以往java程序员要访问office文档,往往要借助各种各样的com组件,jni是难以避免的,因为office文档(word、excel、 ppt)是二进制存储的。但是在许多系统中都要用到office文档,这个java程序员带来了一定的麻烦。  随着office2007的出现,文档存储支持OpenXML,使得java程序读写office文档不用必须借助第三方控件。以word2007为例, 文档存储为*.docx文件,这实际上是一个压缩文件,通过java的ZIPjar包、TAR jar包,都可以访问,可以使用100%纯java代码完成对word2007文件的读取、写入操作。  比较详细的一个例子如下:http://www.infoq.com/articles/cracking-office-2007-with- java,有兴趣的可以去参考一下。  另外,office文档操作也有很多其他方法,比如POI、j-Interop等第三方工具包。

    原文:http://wv19831124.blog.163.com/blog/static/59950007200811585819650/

  • 相关阅读:
    Docker的安装和配置
    SpringBoot如何添加拦截器
    使用Java执行python代码并得到结果
    Redis高可用集群之水平扩展
    Redis集群演变和集群部署
    Redis核心原理
    Redis基本数据结构
    Redis安装和配置
    Typora+PicGo+Gitee笔记方案
    视频描述(Video Captioning)近年重要论文总结
  • 原文地址:https://www.cnblogs.com/gwq369/p/5405405.html
Copyright © 2020-2023  润新知