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%\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;
}
}
}
/**
* 在當前文檔指定的位置拷貝來自另一個文檔中的圖片
*
* @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文件復制到tomcat\bin目錄下重新啟動tomcat5.5
3.使用過程中(將項目發布到Tomcat5下運行時)提示
java.lang.UnsatisfiedLinkError:
Native Library D:\Program Files\Apache Software Foundation\Tomcat 5.5\bin\jacob-1.14.3-x86.dll
already loaded in another classloader
解決:將%Tomcat 5.5%\webapps\XXXX\WEB-INF\lib\下的jacob.jar包剪切到%Tomcat 5.5%\shared\lib目錄下(或刪除).
五.自己改寫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/