`
谷超
  • 浏览: 165986 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

jacob操作word文档(二)

阅读更多
import com.jacob.activeX.ActiveXComponent;
import com.jacob.com.Dispatch;
import com.jacob.com.Variant; 

/**
 * 
 * @author zhuzhen_hua@yahoo.com.cn
 * 
 */ 

public class WordBean {
 // word文档
 private Dispatch doc; 

 // word运行程序对象
 private ActiveXComponent word; 

 // 所有word文档集合
 private Dispatch documents; 

 // 选定的范围或插入点
 private Dispatch selection;
  

 private boolean saveOnExit = true; 

 public WordBean() {
  if (word == null) {
   word = new ActiveXComponent("Word.Application");
   word.setProperty("Visible", new Variant(false));
  }
  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 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-未查找到文本
  */
 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 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();
   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();
    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");
 }
 /**
  * 自动调整表格
  *
  */
    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下
     *
     */
    public void callWordMacro(){
     Dispatch tables = Dispatch.get(doc, "Tables").toDispatch();
     int count = Dispatch.get(tables, "Count").toInt();
     Variant vMacroName = new Variant("Normal.NewMacros.tableFit");
     Variant vParam = new Variant("param1");
     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 savePath
  *            保存或另存为路径
  */
 public void save(String savePath) {
  Dispatch.call(Dispatch.call(word, "WordBasic").getDispatch(),
    "FileSaveAs", savePath);
 } 

 /**
  * 关闭文档
  *@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 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");
  }
 }

//读取表格指定单元格中的内容
 public String getContent(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 Range=Dispatch.get(cell,"Range").toDispatch(); 
	 return Dispatch.get(Range,"Text").toString();
	 
 }

 public static void main(String args[]) {
  WordBean msWordManager = new WordBean();
  try {
  /*
   创建
    msWordManager.createNewDocument(); 
   msWordManager.createTable("", 5, 5);
   msWordManager.mergeCell(1, 1, 1, 1, 5);
   msWordManager.mergeCell(1, 2, 1, 2, 5);
   msWordManager.mergeCell(1, 3, 1, 3, 5);
   msWordManager.putTxtToCell(1,1,1,"主题");
   msWordManager.putTxtToCell(1,2,1,"时间");
   msWordManager.putTxtToCell(1,3,1,"人员");
   msWordManager.putTxtToCell(1,4,2,"说话了");
   msWordManager.save("c:\\asdf1.doc");*/
   msWordManager.openDocument("c:\\asdf1.doc");
   msWordManager.addRow(1);
   msWordManager.putTxtToCell(1, 4, 1, "gaga");
  } catch (Exception e)
   e.printStackTrace();
  }finally{
   msWordManager.close();
  }
 } 

}

 

分享到:
评论
1 楼 xzcqwer 2010-04-08  
   您好,我现在也在搞jacob操作word这块,我遇到了一个问题:
   就是我想快速找到某些文字注释后面的表格对象,然后对表格对象进行各种操作:
   就像下面的word文档片段:
 
   @表格规范
   ---------------------------------------
   |股东编号|  股东类型|股东名称|股东划分|
   ---------------------------------------
   |        |          |        |        |
   ---------------------------------------
  
    @表格规范2
   -------------------------------------------
   |股东编号2|  股东类型2|股东名称2|股东划分2|
   -------------------------------------------
   |         |           |         |         |
   -------------------------------------------

   我想找到“@表格规范”字符串之后,再拿到它下面表格对象的引用;然后找到“@表格规范2”在拿到规范2下的表;
   其实有个折中的方法,就是按照index找到对应的表,然后操作,不过和我最初设想的方式还是有些差距,请问您有什么好的办法?

相关推荐

    jacob 操作word 文档详解

    Jacob 操作 Word 文档详解 Jacob 操作 Word 文档概述 Jacob 是一个 Java 库,用于访问和操作 Microsoft Office 应用程序,包括 Word。它提供了一个基于 COM(Component Object Model)的接口,允许 Java 应用...

    Jacob操作word 文档的方法集!(含创建目录),使用的Jacob版本是1.5

    在这个“Jacob操作word文档的方法集”中,我们将探讨如何使用Jacob 1.5版本来创建和操作Word文档,特别是创建目录。 首先,为了使用Jacob,你需要在你的项目中添加Jacob的jar文件。这通常涉及到将库添加到项目的类...

    jacob操作word文档

    下面将详细阐述Jacob操作Word文档的核心知识点。 1. **Jacob简介** Jacob全称为Java-COM Bridge,是一个开源项目,它的主要作用是提供了一个桥梁,使得Java应用程序能够调用COM组件,进而与Windows系统上的Office...

    jacob操作word文件

    在给定的代码片段中,`GetWord` 类提供了使用Jacob操作Word文档的一些基本功能。 首先,`GetWord` 类初始化了一个`ActiveXComponent` 对象 `word`,这是Jacob库中的一个关键类,用于实例化COM对象,这里是Microsoft...

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

    本文主要探讨如何使用Java-JACOB来创建和操作Word文档。 首先,使用JACOB之前,确保你的系统中已经安装了Microsoft Office,并且配置了相应的COM组件。JACOB本身是一个开源项目,可以在SourceForge上找到...

    Jacob处理Word文档搞定了

    载Jacob_1.11_zip,终于把Jacob处理Word文档搞定了

    Jacob处理Word文档的方法

    在处理Word文档时,我们可以利用Jacob调用Word的COM组件,例如Microsoft.Office.Interop.Word,来实现对Word文档的操作。 要使用Jacob,你需要首先在项目中添加Jacob的库文件。在提供的压缩包`jacob-1.15-M2.zip`中...

    jacob给Word文档添加页脚

    ### jacob给Word文档添加页脚 在日常工作中,Word文档是经常被使用的工具之一,尤其是在需要编写报告、论文或专业文档时。为了使文档更加规范和专业,往往需要添加页眉、页脚等元素。其中,页脚常用于显示页码、...

    jacob实现文档插入到word中

    在本文中,我们将深入探讨如何使用Jacob在Word文档中插入其他文档。 首先,理解Java Jacob的基本使用是至关重要的。Jacob通过COM(Component Object Model)接口与Windows操作系统中的Office应用进行通信。因此,要...

    JACOB操作word和excel示例

    在“如何使用jacob将word转换为PDF.doc”这个示例中,我们将学习如何使用Jacob将Word文档转换成PDF格式。以下是基本步骤: 1. **设置Jacob环境**:首先,你需要在项目中添加Jacob的jar文件,并确保系统路径中包含...

    java_jacob_操作word_文档

    #### 二、Java Jacob 操作 Word 文档的基本流程 1. **初始化 Word 应用程序:** - 创建一个 `ActiveXComponent` 实例,表示 Word 应用程序。 - 设置 Word 应用程序是否可见,这通常取决于是否需要在前台显示 Word...

    jacob 导出word 整理

    Jacob允许Java应用程序通过COM接口与Windows操作系统中的Office应用进行通信,从而实现对Word文档的操作。 Jacob库的核心功能是它提供了Java到COM接口的桥接,使得开发者可以调用Office应用的API来处理Word文档。...

    jacob读取word表格

    标题“jacob读取word表格”涉及到的是使用Jacob库来操作Microsoft Word文档,特别是从中读取表格数据。Jacob是一个Java到COM桥接库,允许Java应用程序调用COM组件,如Microsoft Office的应用程序。 在Java中,直接...

    jacob生成word目录

    本篇文章将深入探讨如何利用JACOB来自动生成Word文档的目录。 首先,我们需要了解什么是目录(TOC,Table of Contents)。在Word文档中,目录是一份列出文档主要部分及其对应页码的索引,帮助读者快速定位到他们感...

    jacob以目录和段落分析读取Word文档(自己写的)

    在这个场景下,我们关注的是使用Jacob库来实现对Word文档的高级操作,特别是通过目录结构分析和读取文档内容。Jacob是一个Java COM自动化桥接库,它允许Java应用程序利用微软Office应用的COM接口,包括Word。 首先...

    java使用jacob工具操作word文档

    总结来说,Java结合JACOB工具提供了一种有效的方法来操作Word文档,无论是读取还是写入,都为开发者提供了便利。然而,这种方式有一定的局限性,特别是在跨平台应用上。通过理解这些基本操作,你可以根据需求灵活地...

    jacob操作word转换成pdf

    在这个场景中,我们将讨论如何利用JACOB将Word文档转换为PDF。 首先,我们需要理解JACOB的工作原理。JACOB是通过Java的JNI(Java Native Interface)来调用COM接口的,这样就可以在Java代码中直接操纵COM对象,例如...

    (转)Java jacob调用打印机打印word文档

    在这个特定的情况下,Jacob被用来调用打印机来打印Word文档。这个过程涉及到几个关键的知识点: 1. **Jacob库**:Jacob全称为Java COM Bridge,是一个开源的Java库,通过JNI(Java Native Interface)技术实现,...

    使用Jacob输出word文档

    NULL 博文链接:https://clq9761.iteye.com/blog/1284318

Global site tag (gtag.js) - Google Analytics