- 浏览: 45700 次
- 性别:
- 来自: 北京
最新评论
最近项目里需要用到word合并功能,本人用的是jacob,以下是本人写的代码
附件上是我用的jacob的版本, jdk1.5.0.9 office 是2007的
package com.cepri.tec.common.cmm;
import java.util.ArrayList;
import java.util.List;
import com.jacob.activeX.ActiveXComponent;
import com.jacob.com.ComThread;
import com.jacob.com.Dispatch;
import com.jacob.com.Variant;
public class GF_JacobUtil {
// 建立一個word物件
private ActiveXComponent MsWordApp = null;
// 建立兩個word組件
private Dispatch document = null;
//selection插入点
private Dispatch selection = null;
//content是word的文档内容
private Dispatch content;
//repalceStr是word的替换对象
private Dispatch repalceStr;
// 建構子
public GF_JacobUtil() {
super();
}
/**
* 開啟word檔案
*
* @param makeVisible
* 顯示不顯示(true:顯示;false:不顯示)
*
*/
public void openWord(boolean makeVisible) {
// 启动com的线程
ComThread.InitSTA();
// 打開word(如果word未開啟時)
if (MsWordApp == null) {
MsWordApp = new ActiveXComponent("Word.Application");
}
// 設置word是可見或不可見(true:顯示;false:不顯示)
Dispatch.put(MsWordApp, "Visible", new Variant(makeVisible));
}
/**
* 建立word的文本內容
*
*/
public void createNewDocument() {
// 建立一個Dispatch物件
Dispatch documents = Dispatch.get(MsWordApp, "Documents").toDispatch();
document = Dispatch.call(documents, "Add").toDispatch();
selection = MsWordApp.getProperty("Selection").toDispatch();
}
/**
* 打开文件
*
* @param inputDoc
* 要打开的文件,全路径
* @return Dispatch 打开的文件
*/
public void openDocument(String inputDoc) {
// 建立一個Dispatch物件
Dispatch documents = Dispatch.get(MsWordApp, "Documents").toDispatch();
document = Dispatch.call(documents, "Open", inputDoc).toDispatch();
selection = MsWordApp.getProperty("Selection").toDispatch();
}
/**
* 选定内容
*
* @return Dispatch 选定的范围或插入点
*/
public Dispatch select() {
return MsWordApp.getProperty("Selection").toDispatch();
}
/**
* 把选定内容或插入点向上移动
*
* @param selection
* 要移动的内容
* @param count
* 移动的距离
*/
public void moveUp(Dispatch selection, int count) {
for (int i = 0; i < count; i++)
Dispatch.call(selection, "MoveUp");
}
/**
* 把选定内容或插入点向下移动
*
* @param selection
* 要移动的内容
* @param count
* 移动的距离
*/
public void moveDown(Dispatch selection, int count) {
for (int i = 0; i < count; i++)
Dispatch.call(selection, "MoveDown");
}
/**
* 把选定内容或插入点向左移动
*
* @param selection
* 要移动的内容
* @param count
* 移动的距离
*/
public void moveLeft(Dispatch selection, int count) {
for (int i = 0; i < count; i++)
Dispatch.call(selection, "MoveLeft");
}
/**
* 把选定内容或插入点向右移动
*
* @param selection
* 要移动的内容
* @param count
* 移动的距离
*/
public void moveRight(Dispatch selection, int count) {
for (int i = 0; i < count; i++)
Dispatch.call(selection, "MoveRight");
}
/**
* 把插入点移动到文件首位置
*
* @param selection
* 插入点
*/
public void moveStart(Dispatch selection) {
Dispatch.call(selection, "HomeKey", new Variant(6));
}
/**
* 从选定内容或插入点开始查找文本
*
* @param selection
* 选定内容
* @param toFindText
* 要查找的文本
* @return boolean true-查找到并选中该文本,false-未查找到文本
*/
public boolean find(Dispatch selection, String toFindText) {
// 从selection所在位置开始查询
Dispatch find = Dispatch.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 selection
* 选定内容
* @param newText
* 替换为文本
*/
public void replace(Dispatch selection, String newText) {
// 设置替换文本
Dispatch.put(selection, "Text", newText);
this.moveRight(selection, 1);
}
/**
* 替换word文件中的内容
* @param oldStr
* @param newStr
*/
public void replace(String oldSoldStrf,String newStr) {
try
{
moveStart(selection);
while(this.find(this.select(), oldSoldStrf))
{
this.replace(selection, newStr);
}
} catch (Exception e) {
System.out.println("word文件替换失败");
e.printStackTrace(System.out);
}
}
/**
* 获取word文件中某个表格的行数
* @param tableIndex
* @param String
*/
public String getTableRowsCount(String tableIndex) {
if(tableIndex == null || "".equals(tableIndex))
tableIndex = "0";
// 所有表格
Dispatch tables = Dispatch.get(document, "Tables").toDispatch();
// 要填充的表格
Dispatch table = Dispatch.call(tables, "Item", new Variant(tableIndex))
.toDispatch();
// 表格的所有行
Dispatch rows = Dispatch.get(table, "Rows").toDispatch();
return new String(""+Dispatch.get(rows, "Count").getInt());
}
/**
* 全局替换
*
* @param selection
* 选定内容或起始插入点
* @param oldText
* 要替换的文本
* @param newText
* 替换为文本
*/
public void replaceAll(Dispatch selection, String oldText, Object replaceObj) {
// 移动到文件开头
moveStart(selection);
if (oldText.startsWith("table") || replaceObj instanceof List) {
replaceTable(selection, oldText, (List) replaceObj);
} else {
String newText = (String) replaceObj;
if (oldText.indexOf("image") != -1
|| newText.lastIndexOf(".bmp") != -1
|| newText.lastIndexOf(".jpg") != -1
|| newText.lastIndexOf(".gif") != -1)
while (find(selection, oldText)) {
replaceImage(selection, newText);
Dispatch.call(selection, "MoveRight");
}
else
while (find(selection, oldText)) {
replace(selection, newText);
Dispatch.call(selection, "MoveRight");
}
}
}
/**
* 替换表格 特殊处理合同模板里面的 项目组成人员的表格
* 需要做的处理:在别的地下先在表格里把项目负责人的数据加载进去,
* 在本方法里面,首先获取 表格的行数,合并第一列,把第一列的值替换为 "项目负责人"
* 然后在原来的基础上添加非项目负责人的数据,最后把 新添加的数据的第一列的值替换为"主要工作人员"
*
* @param tableName
* 表格名称,形如table$1@1、tabletable$2@1...table$R@N@1...table$R@N,R代表从表格中的第N行开始填充, N代表word文件中的第N张表
* @param dataList
* 数据
*/
public void replaceTable(String tableIndex, List dataList) {
// 所有表格
Dispatch tables = Dispatch.get(document, "Tables").toDispatch();
// 要填充的表格
Dispatch table = Dispatch.call(tables, "Item", new Variant(tableIndex))
.toDispatch();
// 首先获取表格的行数
String tableRows = this.getTableRowsCount(tableIndex);
if(Integer.parseInt(tableRows)>1)
{
// 合并 从第二行到最后一行的第一列数据
this.mergeCell( Integer.parseInt(tableIndex), 2, 1, Integer.parseInt(tableRows), 1);
Dispatch mergeCell = Dispatch.call(table, "Cell", new Variant(2),
new Variant(1)).toDispatch();
// 选中单元格
Dispatch.call(mergeCell, "Select");
// 替换表格内容
Dispatch.put(selection, "Text", "项目负责人");
}
if (dataList.size() <= 1) {
System.out.println("Empty mostly person!");
return;
}
// 从第几行开始填充
int fromRow = Integer.parseInt(tableRows)+1;
Object[]obj = null;
// 表格的所有行
Dispatch rows = Dispatch.get(table, "Rows").toDispatch();
// 填充表格
for (int i = 1; i <= dataList.size(); i++) {
// 某一行数据
obj = (Object[]) dataList.get(i-1);
String[] datas = (String[]) obj;
// 在表格中添加一行
if (Dispatch.get(rows, "Count").getInt() < fromRow + i - 1)
Dispatch.call(rows, "Add");
// 填充该行的相关列
for (int j = 0; j < datas.length; j++) {
// 得到单元格
Dispatch cell = Dispatch.call(table, "Cell", new Variant(fromRow + i - 1),
new Variant(j+1)).toDispatch();
// 选中单元格
Dispatch.call(cell, "Select");
Dispatch.put(selection, "Text", datas[j]);
}
}
// 下面将新加的数据的第一列合并,将值改为"主要工作人员"
// 首先获取表格的行数
String tableAllRows = this.getTableRowsCount(tableIndex);
// 合并 从新增数据的第一行到最后一行的第一列单元格进行合并
this.mergeCell( Integer.parseInt(tableIndex), Integer.parseInt(tableRows)+1, 1, Integer.parseInt(tableAllRows), 1);
Dispatch mergeCell2 = Dispatch.call(table, "Cell", new Variant(Integer.parseInt(tableRows)+1),
new Variant(1)).toDispatch();
// 选中单元格
Dispatch.call(mergeCell2, "Select");
// 替换表格内容
Dispatch.put(selection, "Text", "主要工作人员");
}
/**
* 替换表格
*
* @param isNeedSeqNo 表示表格的第一列是不是需要序号(0:不需要序号;1:需要序号)
*
* @param tableName
* 表格名称,形如table$1@1、tabletable$2@1...table$R@N@1...table$R@N,R代表从表格中的第N行开始填充, N代表word文件中的第N张表
* @param dataList
* 数据
*/
public void replaceTable(String tableName, String isNeedSeqNo, List dataList) {
boolean needSeqNo = false;
if("1".equals(isNeedSeqNo))
needSeqNo = true;
if (dataList.size() <= 1) {
System.out.println("Empty table!");
return;
}
// // 要填充的列
Object[] datas = null;
datas = (Object[]) dataList.get(0);
// String[] cols = (String[]) datas;
// 表格序号
String tbIndex = tableName.substring(tableName.lastIndexOf("@") + 1);
// 从第几行开始填充
int fromRow = Integer.parseInt(tableName.substring(tableName
.lastIndexOf("$") + 1, tableName.lastIndexOf("@")));
// 所有表格
Dispatch tables = Dispatch.get(document, "Tables").toDispatch();
// 要填充的表格
Dispatch table = Dispatch.call(tables, "Item", new Variant(tbIndex))
.toDispatch();
// 表格的所有行
Dispatch rows = Dispatch.get(table, "Rows").toDispatch();
// 填充表格
for (int i = 1; i <= dataList.size(); i++) {
// 某一行数据
datas = (Object[]) dataList.get(i-1);
// String[] datas = (String[]) obj;
// 在表格中添加一行
if (Dispatch.get(rows, "Count").getInt() < fromRow + i - 1)
Dispatch.call(rows, "Add");
// 填充该行的相关列
for (int j = 0; j < datas.length; j++) {
// 得到单元格
// Dispatch cell = Dispatch.call(table, "Cell",
// Integer.toString(fromRow + i - 1), cols[j])
// .toDispatch();
Dispatch cell = Dispatch.call(table, "Cell", new Variant(fromRow + i - 1),
new Variant(j+1)).toDispatch();
// 选中单元格
Dispatch.call(cell, "Select");
// 设置格式
// Dispatch font = Dispatch.get(selection, "Font").toDispatch();
// Dispatch.put(font, "Bold", "0");
// Dispatch.put(font, "Italic", "0");
// 输入数据,如果需要序号,则第一列添加序号,否则正常
if(needSeqNo&&j==0)
Dispatch.put(selection, "Text", i+"");
else if(needSeqNo&&j>0)
Dispatch.put(selection, "Text", (String)datas[j]);
else
Dispatch.put(selection, "Text", (String)datas[j+1]);
}
}
}
/**
* 替换合同模板里面的进度计划的表格
* @param selection
* 插入点
* @param tableName
* 表格名称,形如table$1@1、tabletable$2@1...table$R@N@1...table$R@N,R代表从表格中的第N行开始填充, N代表word文件中的第N张表
* @param fields
* 表格中要替换的字段与数据的对应表
*/
public void replaceContract(String tableName, List dataList) {
if (dataList.size() <= 1) {
System.out.println("Empty table!");
return;
}
// 要填充的列
Object[] obj = null;
// 表格序号
String tbIndex = tableName.substring(tableName.lastIndexOf("@") + 1);
// 从第几行开始填充
int fromRow = Integer.parseInt(tableName.substring(tableName
.lastIndexOf("$") + 1, tableName.lastIndexOf("@")));
// 所有表格
Dispatch tables = Dispatch.get(document, "Tables").toDispatch();
// 要填充的表格
Dispatch table = Dispatch.call(tables, "Item", new Variant(tbIndex))
.toDispatch();
// 表格的所有行
Dispatch rows = Dispatch.get(table, "Rows").toDispatch();
// 填充表格
for (int i = 1; i <= dataList.size(); i++) {
// 某一行数据
obj = (Object[]) dataList.get(i-1);
String[] datas = (String[]) obj;
// 在表格中添加一行
if (Dispatch.get(rows, "Count").getInt() < fromRow + i - 1)
Dispatch.call(rows, "Add");
// 填充该行的相关列
for (int j = 0; j < 2; j++) {
// 得到单元格
Dispatch cell = Dispatch.call(table, "Cell", new Variant(fromRow + i - 1),
new Variant(j+1)).toDispatch();
// 选中单元格
Dispatch.call(cell, "Select");
// 设置格式
// Dispatch font = Dispatch.get(selection, "Font").toDispatch();
// Dispatch.put(font, "Bold", "0");
// Dispatch.put(font, "Italic", "0");
// 输入数据
if(j == 0)
Dispatch.put(selection, "Text", "5."+(j+1));
else
{
String temp = "";
temp = datas[1]+"-"+datas[2]+"\n"+"主要内容:"+datas[3]+"\n"+"考核目标:"+datas[4];
Dispatch.put(selection, "Text", temp);
}
}
}
}
/**
* 替换表格
*
* @param selection
* 插入点
* @param tableName
* 表格名称,形如table$1@1、tabletable$2@1...table$R@N@1...table$R@N,R代表从表格中的第N行开始填充, N代表word文件中的第N张表
* @param fields
* 表格中要替换的字段与数据的对应表
*/
public void replaceTable(Dispatch selection, String tableName, List dataList) {
if (dataList.size() <= 1) {
System.out.println("Empty table!");
return;
}
// 要填充的列
Object[] obj = null;
// String[] cols = (String[]) dataList.get(0);
// 表格序号
String tbIndex = tableName.substring(tableName.lastIndexOf("@") + 1);
// 从第几行开始填充
int fromRow = Integer.parseInt(tableName.substring(tableName
.lastIndexOf("$") + 1, tableName.lastIndexOf("@")));
// 所有表格
Dispatch tables = Dispatch.get(document, "Tables").toDispatch();
// 要填充的表格
Dispatch table = Dispatch.call(tables, "Item", new Variant(tbIndex))
.toDispatch();
// 表格的所有行
Dispatch rows = Dispatch.get(table, "Rows").toDispatch();
// 填充表格
for (int i = 1; i <= dataList.size(); i++) {
// 某一行数据
obj = (Object[]) dataList.get(i-1);
String[] datas = (String[]) obj;
// 在表格中添加一行
if (Dispatch.get(rows, "Count").getInt() < fromRow + i - 1)
Dispatch.call(rows, "Add");
// 填充该行的相关列
for (int j = 0; j < datas.length; j++) {
// 得到单元格
// Dispatch cell = Dispatch.call(table, "Cell",
// Integer.toString(fromRow + i - 1), cols[j])
// .toDispatch();
Dispatch cell = Dispatch.call(table, "Cell", new Variant(fromRow + i - 1),
new Variant(j+1)).toDispatch();
// 选中单元格
Dispatch.call(cell, "Select");
// 设置格式
Dispatch font = Dispatch.get(selection, "Font").toDispatch();
Dispatch.put(font, "Bold", "0");
Dispatch.put(font, "Italic", "0");
// 输入数据
Dispatch.put(selection, "Text", datas[j]);
// this.moveRight(selection, 1);
}
// this.moveDown(selection, count)
// this.moveRight(selection, 1);
}
}
/**
* 寫入换行到word中
*
* @param text
* 本文標題
*
*/
public void insertSplit() {
selection = Dispatch.get(MsWordApp, "Selection").toDispatch(); // 輸入內容需要的物件
// Dispatch alignment = Dispatch.get(selection, "ParagraphFormat")
// .toDispatch(); // 行列格式化需要的物件
// Dispatch.call(selection, "TypeText", ""); // 寫入標題內容
// Dispatch.call(selection, "TypeParagraph"); // 空一行段落
// Dispatch.put(alignment, "Alignment", "3"); // (1:置中 2:靠右 3:靠左)
Dispatch.call(selection, "MoveRight"); // 游標往下一行
}
/**
* 合併表格
*
* @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(document, "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);
}
/**
* 自動調整表格
*
*/
public void autoFitTable() {
Dispatch tables = Dispatch.get(document, "Tables").toDispatch();
int count = Dispatch.get(tables, "Count").getInt(); // word中的表格數量
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");
}
}
/**
* 替换图片
*
* @param selection
* 图片的插入点
* @param imagePath
* 图片文件(全路径)
*/
public void replaceImage(Dispatch selection, String imagePath) {
Dispatch.call(Dispatch.get(selection, "InLineShapes").toDispatch(),
"AddPicture", imagePath);
}
/**
* 功能: 在文件的当前插入点插入文件
* @param path void
*/
public void insertFile(String path) {
// selection = Dispatch.get(MsWordApp, "Selection").toDispatch();
// Dispatch.call(selection, "MoveDown");
Dispatch.invoke(selection, "insertFile", Dispatch.Method, new Object[] {
path, "", new Variant(false), new Variant(false),
new Variant(false) }, new int[3]);
// this.moveStart(selection);
}
/**
* 功能: 在文件的插入点插入文件
* @param selection 文件的插入点
* @param path void
*/
public void insertFile(Dispatch selection,String path) {
Dispatch.invoke(selection, "insertFile", Dispatch.Method, new Object[] {
path, "", new Variant(false), new Variant(false),
new Variant(false) }, new int[3]);
}
/**
* 往word中插入table
*
*/
public void insertTable(String rows,String cols) {
// 建立表格
Dispatch tables = Dispatch.get(document, "Tables").toDispatch();
Dispatch range = Dispatch.get(selection, "Range").toDispatch();
Dispatch.call(tables, "Add", range, new Variant(cols), new Variant(rows),
new Variant(1)).toDispatch(); // 設置列數,欄數,表格外框寬度
Dispatch.call(selection, "MoveRight"); // 游標移到最右邊
}
/**
* 往表格中插入word文件
*
*/
public void insertFileToTable(String path, int tableIndex) {
Dispatch tables = Dispatch.get(document, "Tables").toDispatch();
Dispatch table = Dispatch.call(tables, "Item", new Variant(tableIndex))
.toDispatch();
Dispatch cell = Dispatch.call(table, "Cell", new Variant(1),
new Variant(1)).toDispatch();
Dispatch.call(cell, "Select");
selection = Dispatch.get(MsWordApp, "Selection").toDispatch();
// 主要內容
try {
Dispatch.invoke(selection, "insertFile", Dispatch.Method, new Object[] {
path, "", new Variant(false), new Variant(false),
new Variant(false) }, new int[3]);
} catch (Exception e) {
e.printStackTrace();
// 主要內容
Dispatch alignment = Dispatch.get(selection, "ParagraphFormat")
.toDispatch(); // 行列格式化需要的物件
Dispatch font1 = Dispatch.get(selection, "Font").toDispatch();
// 文件標題
// Dispatch.call(selection, "TypeParagraph"); //空一行段落;
Dispatch.put(alignment, "Alignment", "3"); // (1:置中 2:靠右 3:靠左)
Dispatch.put(font1, "Bold", "0"); // 字型租體
Dispatch.put(font1, "Size", "12"); // 字型大小
Dispatch.put(font1, "Color", "0,0,0,0"); // 字型顏色(1,0,0,0=>紅色
// 1,1,0,0=>棕色)
// Dispatch.put(font, "Italic", "1"); //字型斜體
Dispatch.call(selection, "TypeText", path); // 寫入標題內容
// 標題格行
Dispatch.call(selection, "TypeParagraph"); // 空一行段落
Dispatch.put(alignment, "Alignment", "3"); // (1:置中 2:靠右 3:靠左)
Dispatch.call(selection, "MoveDown"); // 游標往下一行
}
// 取消選擇(因為最後insert進去的文字會顯示反白,所以要取消)
Dispatch.call(selection, "MoveRight", new Variant(1), new Variant(1));
insertSplit();
}
public void insertTextToTable(String text, int tableIndex) {
Dispatch tables = Dispatch.get(document, "Tables").toDispatch();
Dispatch table = Dispatch.call(tables, "Item", new Variant(tableIndex))
.toDispatch();
Dispatch cell = Dispatch.call(table, "Cell", new Variant(1),
new Variant(1)).toDispatch();
Dispatch.call(cell, "Select");
selection = Dispatch.get(MsWordApp, "Selection").toDispatch();
// 主要內容
Dispatch alignment = Dispatch.get(selection, "ParagraphFormat")
.toDispatch(); // 行列格式化需要的物件
Dispatch font1 = Dispatch.get(selection, "Font").toDispatch();
// 文件標題
// Dispatch.call(selection, "TypeParagraph"); //空一行段落
Dispatch.put(alignment, "Alignment", "3"); // (1:置中 2:靠右 3:靠左)
Dispatch.put(font1, "Bold", "0"); // 字型租體
Dispatch.put(font1, "Size", "12"); // 字型大小
Dispatch.put(font1, "Color", "0,0,0,0"); // 字型顏色(1,0,0,0=>紅色
// 1,1,0,0=>棕色)
// Dispatch.put(font, "Italic", "1"); //字型斜體
Dispatch.call(selection, "TypeText", text); // 寫入標題內容
// 標題格行
Dispatch.call(selection, "TypeParagraph"); // 空一行段落
Dispatch.put(alignment, "Alignment", "3"); // (1:置中 2:靠右 3:靠左)
Dispatch.call(selection, "MoveDown"); // 游標往下一行
// 取消選擇(因為最後insert進去的文字會顯示反白,所以要取消)
Dispatch.call(selection, "MoveRight", new Variant(1), new Variant(1));
insertSplit();
}
/** 另存檔案
*
* @param filename
* 要儲存的檔案名稱
*
*/
public void saveFileAs(String filename) {
Dispatch.call(document, "SaveAs", filename);
}
/**
* 列印word文件
*
*/
public void printFile() {
Dispatch.call(document, "PrintOut");
}
/**
* 關閉文本內容(如果未開啟word編輯時,釋放ActiveX執行緒)
*
*/
public void closeDocument() {
// 0 = 沒有儲存改變
// -1 = 有儲存改變
// -2 = 提示儲存改變
Dispatch.call(document, "Close", new Variant(0));
document = null;
}
/**
* 關閉word(如果未開啟word編輯時,釋放ActiveX執行緒)
*
*/
public void closeWord() {
Dispatch.call(MsWordApp, "Quit");
MsWordApp = null;
document = null;
ComThread.Release();
}
public static void main(String []args)
{
String otFile = "G:/jacob_template/temp/temp_contract.doc"; // 目標文件位置
String rsFile = "G:/jacob_template/template_contract.doc"; // 待插入文件的文件位置
String templateFile = "G:/jacob_template/template_advise.doc"; // 模板文件位置
GF_JacobUtil word = new GF_JacobUtil(); // 建立一個WordExtractor物件
try
{
String tableName = "tabletable$3@5";
List<String[]> dataList = new ArrayList<String[]>();
String[] str1 = new String[]{"一、1111詳察具復之 ","總公司>董事長室回覆:申覆處理或申述查明情由與","擬辦: 本案擬結案。 1111"};
String[] str2 = new String[]{"二、金融商品買賣作業1詳察具復之","總公司>董事長室回覆:申覆處理或申述查明情由與","擬辦: 本案擬結案。 tttt申覆處理或申述查明情由"};
String[] str3 = new String[]{"三、CI-101(金融商品買賣作業):詳察具復之","總公司>董事長室回覆:申覆處理或申述查明情由與","擬辦: 本案擬結案。 31231"};
String[] str4 = new String[]{"四、標題詳察具復之 ","總公司>董事長室回覆:申覆處理或申述查明情由與","擬辦: 本案擬結案。擬辦"};
String[] str5 = new String[]{"五、12312","擬辦: 本案擬結案。碁碁碁珮許功蓋","擬辦: 本案擬結案。 31231"};
dataList.add(str1);
dataList.add(str2);
dataList.add(str3);
dataList.add(str4);
dataList.add(str5);
word.openWord(true); // 設定word開啟顯示
word.openDocument(templateFile);// 建立文件內容
word.replace("@projectName@", "jacob项目测试");
word.replaceTable(word.select(), tableName, dataList);
word.find(word.select(), "#插入文件测试#");
word.insertFile(word.select(), rsFile);
word.insertFile( rsFile);
word.find(word.select(), "[项目背景]");
word.moveDown(word.select(), 1);
word.insertFile( rsFile);
word.saveFileAs(otFile);
}
catch(Exception ex)
{
ex.printStackTrace();
}
finally
{
word.closeDocument();
word.closeWord();
}
}
}
附件上是我用的jacob的版本, jdk1.5.0.9 office 是2007的
package com.cepri.tec.common.cmm;
import java.util.ArrayList;
import java.util.List;
import com.jacob.activeX.ActiveXComponent;
import com.jacob.com.ComThread;
import com.jacob.com.Dispatch;
import com.jacob.com.Variant;
public class GF_JacobUtil {
// 建立一個word物件
private ActiveXComponent MsWordApp = null;
// 建立兩個word組件
private Dispatch document = null;
//selection插入点
private Dispatch selection = null;
//content是word的文档内容
private Dispatch content;
//repalceStr是word的替换对象
private Dispatch repalceStr;
// 建構子
public GF_JacobUtil() {
super();
}
/**
* 開啟word檔案
*
* @param makeVisible
* 顯示不顯示(true:顯示;false:不顯示)
*
*/
public void openWord(boolean makeVisible) {
// 启动com的线程
ComThread.InitSTA();
// 打開word(如果word未開啟時)
if (MsWordApp == null) {
MsWordApp = new ActiveXComponent("Word.Application");
}
// 設置word是可見或不可見(true:顯示;false:不顯示)
Dispatch.put(MsWordApp, "Visible", new Variant(makeVisible));
}
/**
* 建立word的文本內容
*
*/
public void createNewDocument() {
// 建立一個Dispatch物件
Dispatch documents = Dispatch.get(MsWordApp, "Documents").toDispatch();
document = Dispatch.call(documents, "Add").toDispatch();
selection = MsWordApp.getProperty("Selection").toDispatch();
}
/**
* 打开文件
*
* @param inputDoc
* 要打开的文件,全路径
* @return Dispatch 打开的文件
*/
public void openDocument(String inputDoc) {
// 建立一個Dispatch物件
Dispatch documents = Dispatch.get(MsWordApp, "Documents").toDispatch();
document = Dispatch.call(documents, "Open", inputDoc).toDispatch();
selection = MsWordApp.getProperty("Selection").toDispatch();
}
/**
* 选定内容
*
* @return Dispatch 选定的范围或插入点
*/
public Dispatch select() {
return MsWordApp.getProperty("Selection").toDispatch();
}
/**
* 把选定内容或插入点向上移动
*
* @param selection
* 要移动的内容
* @param count
* 移动的距离
*/
public void moveUp(Dispatch selection, int count) {
for (int i = 0; i < count; i++)
Dispatch.call(selection, "MoveUp");
}
/**
* 把选定内容或插入点向下移动
*
* @param selection
* 要移动的内容
* @param count
* 移动的距离
*/
public void moveDown(Dispatch selection, int count) {
for (int i = 0; i < count; i++)
Dispatch.call(selection, "MoveDown");
}
/**
* 把选定内容或插入点向左移动
*
* @param selection
* 要移动的内容
* @param count
* 移动的距离
*/
public void moveLeft(Dispatch selection, int count) {
for (int i = 0; i < count; i++)
Dispatch.call(selection, "MoveLeft");
}
/**
* 把选定内容或插入点向右移动
*
* @param selection
* 要移动的内容
* @param count
* 移动的距离
*/
public void moveRight(Dispatch selection, int count) {
for (int i = 0; i < count; i++)
Dispatch.call(selection, "MoveRight");
}
/**
* 把插入点移动到文件首位置
*
* @param selection
* 插入点
*/
public void moveStart(Dispatch selection) {
Dispatch.call(selection, "HomeKey", new Variant(6));
}
/**
* 从选定内容或插入点开始查找文本
*
* @param selection
* 选定内容
* @param toFindText
* 要查找的文本
* @return boolean true-查找到并选中该文本,false-未查找到文本
*/
public boolean find(Dispatch selection, String toFindText) {
// 从selection所在位置开始查询
Dispatch find = Dispatch.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 selection
* 选定内容
* @param newText
* 替换为文本
*/
public void replace(Dispatch selection, String newText) {
// 设置替换文本
Dispatch.put(selection, "Text", newText);
this.moveRight(selection, 1);
}
/**
* 替换word文件中的内容
* @param oldStr
* @param newStr
*/
public void replace(String oldSoldStrf,String newStr) {
try
{
moveStart(selection);
while(this.find(this.select(), oldSoldStrf))
{
this.replace(selection, newStr);
}
} catch (Exception e) {
System.out.println("word文件替换失败");
e.printStackTrace(System.out);
}
}
/**
* 获取word文件中某个表格的行数
* @param tableIndex
* @param String
*/
public String getTableRowsCount(String tableIndex) {
if(tableIndex == null || "".equals(tableIndex))
tableIndex = "0";
// 所有表格
Dispatch tables = Dispatch.get(document, "Tables").toDispatch();
// 要填充的表格
Dispatch table = Dispatch.call(tables, "Item", new Variant(tableIndex))
.toDispatch();
// 表格的所有行
Dispatch rows = Dispatch.get(table, "Rows").toDispatch();
return new String(""+Dispatch.get(rows, "Count").getInt());
}
/**
* 全局替换
*
* @param selection
* 选定内容或起始插入点
* @param oldText
* 要替换的文本
* @param newText
* 替换为文本
*/
public void replaceAll(Dispatch selection, String oldText, Object replaceObj) {
// 移动到文件开头
moveStart(selection);
if (oldText.startsWith("table") || replaceObj instanceof List) {
replaceTable(selection, oldText, (List) replaceObj);
} else {
String newText = (String) replaceObj;
if (oldText.indexOf("image") != -1
|| newText.lastIndexOf(".bmp") != -1
|| newText.lastIndexOf(".jpg") != -1
|| newText.lastIndexOf(".gif") != -1)
while (find(selection, oldText)) {
replaceImage(selection, newText);
Dispatch.call(selection, "MoveRight");
}
else
while (find(selection, oldText)) {
replace(selection, newText);
Dispatch.call(selection, "MoveRight");
}
}
}
/**
* 替换表格 特殊处理合同模板里面的 项目组成人员的表格
* 需要做的处理:在别的地下先在表格里把项目负责人的数据加载进去,
* 在本方法里面,首先获取 表格的行数,合并第一列,把第一列的值替换为 "项目负责人"
* 然后在原来的基础上添加非项目负责人的数据,最后把 新添加的数据的第一列的值替换为"主要工作人员"
*
* @param tableName
* 表格名称,形如table$1@1、tabletable$2@1...table$R@N@1...table$R@N,R代表从表格中的第N行开始填充, N代表word文件中的第N张表
* @param dataList
* 数据
*/
public void replaceTable(String tableIndex, List dataList) {
// 所有表格
Dispatch tables = Dispatch.get(document, "Tables").toDispatch();
// 要填充的表格
Dispatch table = Dispatch.call(tables, "Item", new Variant(tableIndex))
.toDispatch();
// 首先获取表格的行数
String tableRows = this.getTableRowsCount(tableIndex);
if(Integer.parseInt(tableRows)>1)
{
// 合并 从第二行到最后一行的第一列数据
this.mergeCell( Integer.parseInt(tableIndex), 2, 1, Integer.parseInt(tableRows), 1);
Dispatch mergeCell = Dispatch.call(table, "Cell", new Variant(2),
new Variant(1)).toDispatch();
// 选中单元格
Dispatch.call(mergeCell, "Select");
// 替换表格内容
Dispatch.put(selection, "Text", "项目负责人");
}
if (dataList.size() <= 1) {
System.out.println("Empty mostly person!");
return;
}
// 从第几行开始填充
int fromRow = Integer.parseInt(tableRows)+1;
Object[]obj = null;
// 表格的所有行
Dispatch rows = Dispatch.get(table, "Rows").toDispatch();
// 填充表格
for (int i = 1; i <= dataList.size(); i++) {
// 某一行数据
obj = (Object[]) dataList.get(i-1);
String[] datas = (String[]) obj;
// 在表格中添加一行
if (Dispatch.get(rows, "Count").getInt() < fromRow + i - 1)
Dispatch.call(rows, "Add");
// 填充该行的相关列
for (int j = 0; j < datas.length; j++) {
// 得到单元格
Dispatch cell = Dispatch.call(table, "Cell", new Variant(fromRow + i - 1),
new Variant(j+1)).toDispatch();
// 选中单元格
Dispatch.call(cell, "Select");
Dispatch.put(selection, "Text", datas[j]);
}
}
// 下面将新加的数据的第一列合并,将值改为"主要工作人员"
// 首先获取表格的行数
String tableAllRows = this.getTableRowsCount(tableIndex);
// 合并 从新增数据的第一行到最后一行的第一列单元格进行合并
this.mergeCell( Integer.parseInt(tableIndex), Integer.parseInt(tableRows)+1, 1, Integer.parseInt(tableAllRows), 1);
Dispatch mergeCell2 = Dispatch.call(table, "Cell", new Variant(Integer.parseInt(tableRows)+1),
new Variant(1)).toDispatch();
// 选中单元格
Dispatch.call(mergeCell2, "Select");
// 替换表格内容
Dispatch.put(selection, "Text", "主要工作人员");
}
/**
* 替换表格
*
* @param isNeedSeqNo 表示表格的第一列是不是需要序号(0:不需要序号;1:需要序号)
*
* @param tableName
* 表格名称,形如table$1@1、tabletable$2@1...table$R@N@1...table$R@N,R代表从表格中的第N行开始填充, N代表word文件中的第N张表
* @param dataList
* 数据
*/
public void replaceTable(String tableName, String isNeedSeqNo, List dataList) {
boolean needSeqNo = false;
if("1".equals(isNeedSeqNo))
needSeqNo = true;
if (dataList.size() <= 1) {
System.out.println("Empty table!");
return;
}
// // 要填充的列
Object[] datas = null;
datas = (Object[]) dataList.get(0);
// String[] cols = (String[]) datas;
// 表格序号
String tbIndex = tableName.substring(tableName.lastIndexOf("@") + 1);
// 从第几行开始填充
int fromRow = Integer.parseInt(tableName.substring(tableName
.lastIndexOf("$") + 1, tableName.lastIndexOf("@")));
// 所有表格
Dispatch tables = Dispatch.get(document, "Tables").toDispatch();
// 要填充的表格
Dispatch table = Dispatch.call(tables, "Item", new Variant(tbIndex))
.toDispatch();
// 表格的所有行
Dispatch rows = Dispatch.get(table, "Rows").toDispatch();
// 填充表格
for (int i = 1; i <= dataList.size(); i++) {
// 某一行数据
datas = (Object[]) dataList.get(i-1);
// String[] datas = (String[]) obj;
// 在表格中添加一行
if (Dispatch.get(rows, "Count").getInt() < fromRow + i - 1)
Dispatch.call(rows, "Add");
// 填充该行的相关列
for (int j = 0; j < datas.length; j++) {
// 得到单元格
// Dispatch cell = Dispatch.call(table, "Cell",
// Integer.toString(fromRow + i - 1), cols[j])
// .toDispatch();
Dispatch cell = Dispatch.call(table, "Cell", new Variant(fromRow + i - 1),
new Variant(j+1)).toDispatch();
// 选中单元格
Dispatch.call(cell, "Select");
// 设置格式
// Dispatch font = Dispatch.get(selection, "Font").toDispatch();
// Dispatch.put(font, "Bold", "0");
// Dispatch.put(font, "Italic", "0");
// 输入数据,如果需要序号,则第一列添加序号,否则正常
if(needSeqNo&&j==0)
Dispatch.put(selection, "Text", i+"");
else if(needSeqNo&&j>0)
Dispatch.put(selection, "Text", (String)datas[j]);
else
Dispatch.put(selection, "Text", (String)datas[j+1]);
}
}
}
/**
* 替换合同模板里面的进度计划的表格
* @param selection
* 插入点
* @param tableName
* 表格名称,形如table$1@1、tabletable$2@1...table$R@N@1...table$R@N,R代表从表格中的第N行开始填充, N代表word文件中的第N张表
* @param fields
* 表格中要替换的字段与数据的对应表
*/
public void replaceContract(String tableName, List dataList) {
if (dataList.size() <= 1) {
System.out.println("Empty table!");
return;
}
// 要填充的列
Object[] obj = null;
// 表格序号
String tbIndex = tableName.substring(tableName.lastIndexOf("@") + 1);
// 从第几行开始填充
int fromRow = Integer.parseInt(tableName.substring(tableName
.lastIndexOf("$") + 1, tableName.lastIndexOf("@")));
// 所有表格
Dispatch tables = Dispatch.get(document, "Tables").toDispatch();
// 要填充的表格
Dispatch table = Dispatch.call(tables, "Item", new Variant(tbIndex))
.toDispatch();
// 表格的所有行
Dispatch rows = Dispatch.get(table, "Rows").toDispatch();
// 填充表格
for (int i = 1; i <= dataList.size(); i++) {
// 某一行数据
obj = (Object[]) dataList.get(i-1);
String[] datas = (String[]) obj;
// 在表格中添加一行
if (Dispatch.get(rows, "Count").getInt() < fromRow + i - 1)
Dispatch.call(rows, "Add");
// 填充该行的相关列
for (int j = 0; j < 2; j++) {
// 得到单元格
Dispatch cell = Dispatch.call(table, "Cell", new Variant(fromRow + i - 1),
new Variant(j+1)).toDispatch();
// 选中单元格
Dispatch.call(cell, "Select");
// 设置格式
// Dispatch font = Dispatch.get(selection, "Font").toDispatch();
// Dispatch.put(font, "Bold", "0");
// Dispatch.put(font, "Italic", "0");
// 输入数据
if(j == 0)
Dispatch.put(selection, "Text", "5."+(j+1));
else
{
String temp = "";
temp = datas[1]+"-"+datas[2]+"\n"+"主要内容:"+datas[3]+"\n"+"考核目标:"+datas[4];
Dispatch.put(selection, "Text", temp);
}
}
}
}
/**
* 替换表格
*
* @param selection
* 插入点
* @param tableName
* 表格名称,形如table$1@1、tabletable$2@1...table$R@N@1...table$R@N,R代表从表格中的第N行开始填充, N代表word文件中的第N张表
* @param fields
* 表格中要替换的字段与数据的对应表
*/
public void replaceTable(Dispatch selection, String tableName, List dataList) {
if (dataList.size() <= 1) {
System.out.println("Empty table!");
return;
}
// 要填充的列
Object[] obj = null;
// String[] cols = (String[]) dataList.get(0);
// 表格序号
String tbIndex = tableName.substring(tableName.lastIndexOf("@") + 1);
// 从第几行开始填充
int fromRow = Integer.parseInt(tableName.substring(tableName
.lastIndexOf("$") + 1, tableName.lastIndexOf("@")));
// 所有表格
Dispatch tables = Dispatch.get(document, "Tables").toDispatch();
// 要填充的表格
Dispatch table = Dispatch.call(tables, "Item", new Variant(tbIndex))
.toDispatch();
// 表格的所有行
Dispatch rows = Dispatch.get(table, "Rows").toDispatch();
// 填充表格
for (int i = 1; i <= dataList.size(); i++) {
// 某一行数据
obj = (Object[]) dataList.get(i-1);
String[] datas = (String[]) obj;
// 在表格中添加一行
if (Dispatch.get(rows, "Count").getInt() < fromRow + i - 1)
Dispatch.call(rows, "Add");
// 填充该行的相关列
for (int j = 0; j < datas.length; j++) {
// 得到单元格
// Dispatch cell = Dispatch.call(table, "Cell",
// Integer.toString(fromRow + i - 1), cols[j])
// .toDispatch();
Dispatch cell = Dispatch.call(table, "Cell", new Variant(fromRow + i - 1),
new Variant(j+1)).toDispatch();
// 选中单元格
Dispatch.call(cell, "Select");
// 设置格式
Dispatch font = Dispatch.get(selection, "Font").toDispatch();
Dispatch.put(font, "Bold", "0");
Dispatch.put(font, "Italic", "0");
// 输入数据
Dispatch.put(selection, "Text", datas[j]);
// this.moveRight(selection, 1);
}
// this.moveDown(selection, count)
// this.moveRight(selection, 1);
}
}
/**
* 寫入换行到word中
*
* @param text
* 本文標題
*
*/
public void insertSplit() {
selection = Dispatch.get(MsWordApp, "Selection").toDispatch(); // 輸入內容需要的物件
// Dispatch alignment = Dispatch.get(selection, "ParagraphFormat")
// .toDispatch(); // 行列格式化需要的物件
// Dispatch.call(selection, "TypeText", ""); // 寫入標題內容
// Dispatch.call(selection, "TypeParagraph"); // 空一行段落
// Dispatch.put(alignment, "Alignment", "3"); // (1:置中 2:靠右 3:靠左)
Dispatch.call(selection, "MoveRight"); // 游標往下一行
}
/**
* 合併表格
*
* @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(document, "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);
}
/**
* 自動調整表格
*
*/
public void autoFitTable() {
Dispatch tables = Dispatch.get(document, "Tables").toDispatch();
int count = Dispatch.get(tables, "Count").getInt(); // word中的表格數量
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");
}
}
/**
* 替换图片
*
* @param selection
* 图片的插入点
* @param imagePath
* 图片文件(全路径)
*/
public void replaceImage(Dispatch selection, String imagePath) {
Dispatch.call(Dispatch.get(selection, "InLineShapes").toDispatch(),
"AddPicture", imagePath);
}
/**
* 功能: 在文件的当前插入点插入文件
* @param path void
*/
public void insertFile(String path) {
// selection = Dispatch.get(MsWordApp, "Selection").toDispatch();
// Dispatch.call(selection, "MoveDown");
Dispatch.invoke(selection, "insertFile", Dispatch.Method, new Object[] {
path, "", new Variant(false), new Variant(false),
new Variant(false) }, new int[3]);
// this.moveStart(selection);
}
/**
* 功能: 在文件的插入点插入文件
* @param selection 文件的插入点
* @param path void
*/
public void insertFile(Dispatch selection,String path) {
Dispatch.invoke(selection, "insertFile", Dispatch.Method, new Object[] {
path, "", new Variant(false), new Variant(false),
new Variant(false) }, new int[3]);
}
/**
* 往word中插入table
*
*/
public void insertTable(String rows,String cols) {
// 建立表格
Dispatch tables = Dispatch.get(document, "Tables").toDispatch();
Dispatch range = Dispatch.get(selection, "Range").toDispatch();
Dispatch.call(tables, "Add", range, new Variant(cols), new Variant(rows),
new Variant(1)).toDispatch(); // 設置列數,欄數,表格外框寬度
Dispatch.call(selection, "MoveRight"); // 游標移到最右邊
}
/**
* 往表格中插入word文件
*
*/
public void insertFileToTable(String path, int tableIndex) {
Dispatch tables = Dispatch.get(document, "Tables").toDispatch();
Dispatch table = Dispatch.call(tables, "Item", new Variant(tableIndex))
.toDispatch();
Dispatch cell = Dispatch.call(table, "Cell", new Variant(1),
new Variant(1)).toDispatch();
Dispatch.call(cell, "Select");
selection = Dispatch.get(MsWordApp, "Selection").toDispatch();
// 主要內容
try {
Dispatch.invoke(selection, "insertFile", Dispatch.Method, new Object[] {
path, "", new Variant(false), new Variant(false),
new Variant(false) }, new int[3]);
} catch (Exception e) {
e.printStackTrace();
// 主要內容
Dispatch alignment = Dispatch.get(selection, "ParagraphFormat")
.toDispatch(); // 行列格式化需要的物件
Dispatch font1 = Dispatch.get(selection, "Font").toDispatch();
// 文件標題
// Dispatch.call(selection, "TypeParagraph"); //空一行段落;
Dispatch.put(alignment, "Alignment", "3"); // (1:置中 2:靠右 3:靠左)
Dispatch.put(font1, "Bold", "0"); // 字型租體
Dispatch.put(font1, "Size", "12"); // 字型大小
Dispatch.put(font1, "Color", "0,0,0,0"); // 字型顏色(1,0,0,0=>紅色
// 1,1,0,0=>棕色)
// Dispatch.put(font, "Italic", "1"); //字型斜體
Dispatch.call(selection, "TypeText", path); // 寫入標題內容
// 標題格行
Dispatch.call(selection, "TypeParagraph"); // 空一行段落
Dispatch.put(alignment, "Alignment", "3"); // (1:置中 2:靠右 3:靠左)
Dispatch.call(selection, "MoveDown"); // 游標往下一行
}
// 取消選擇(因為最後insert進去的文字會顯示反白,所以要取消)
Dispatch.call(selection, "MoveRight", new Variant(1), new Variant(1));
insertSplit();
}
public void insertTextToTable(String text, int tableIndex) {
Dispatch tables = Dispatch.get(document, "Tables").toDispatch();
Dispatch table = Dispatch.call(tables, "Item", new Variant(tableIndex))
.toDispatch();
Dispatch cell = Dispatch.call(table, "Cell", new Variant(1),
new Variant(1)).toDispatch();
Dispatch.call(cell, "Select");
selection = Dispatch.get(MsWordApp, "Selection").toDispatch();
// 主要內容
Dispatch alignment = Dispatch.get(selection, "ParagraphFormat")
.toDispatch(); // 行列格式化需要的物件
Dispatch font1 = Dispatch.get(selection, "Font").toDispatch();
// 文件標題
// Dispatch.call(selection, "TypeParagraph"); //空一行段落
Dispatch.put(alignment, "Alignment", "3"); // (1:置中 2:靠右 3:靠左)
Dispatch.put(font1, "Bold", "0"); // 字型租體
Dispatch.put(font1, "Size", "12"); // 字型大小
Dispatch.put(font1, "Color", "0,0,0,0"); // 字型顏色(1,0,0,0=>紅色
// 1,1,0,0=>棕色)
// Dispatch.put(font, "Italic", "1"); //字型斜體
Dispatch.call(selection, "TypeText", text); // 寫入標題內容
// 標題格行
Dispatch.call(selection, "TypeParagraph"); // 空一行段落
Dispatch.put(alignment, "Alignment", "3"); // (1:置中 2:靠右 3:靠左)
Dispatch.call(selection, "MoveDown"); // 游標往下一行
// 取消選擇(因為最後insert進去的文字會顯示反白,所以要取消)
Dispatch.call(selection, "MoveRight", new Variant(1), new Variant(1));
insertSplit();
}
/** 另存檔案
*
* @param filename
* 要儲存的檔案名稱
*
*/
public void saveFileAs(String filename) {
Dispatch.call(document, "SaveAs", filename);
}
/**
* 列印word文件
*
*/
public void printFile() {
Dispatch.call(document, "PrintOut");
}
/**
* 關閉文本內容(如果未開啟word編輯時,釋放ActiveX執行緒)
*
*/
public void closeDocument() {
// 0 = 沒有儲存改變
// -1 = 有儲存改變
// -2 = 提示儲存改變
Dispatch.call(document, "Close", new Variant(0));
document = null;
}
/**
* 關閉word(如果未開啟word編輯時,釋放ActiveX執行緒)
*
*/
public void closeWord() {
Dispatch.call(MsWordApp, "Quit");
MsWordApp = null;
document = null;
ComThread.Release();
}
public static void main(String []args)
{
String otFile = "G:/jacob_template/temp/temp_contract.doc"; // 目標文件位置
String rsFile = "G:/jacob_template/template_contract.doc"; // 待插入文件的文件位置
String templateFile = "G:/jacob_template/template_advise.doc"; // 模板文件位置
GF_JacobUtil word = new GF_JacobUtil(); // 建立一個WordExtractor物件
try
{
String tableName = "tabletable$3@5";
List<String[]> dataList = new ArrayList<String[]>();
String[] str1 = new String[]{"一、1111詳察具復之 ","總公司>董事長室回覆:申覆處理或申述查明情由與","擬辦: 本案擬結案。 1111"};
String[] str2 = new String[]{"二、金融商品買賣作業1詳察具復之","總公司>董事長室回覆:申覆處理或申述查明情由與","擬辦: 本案擬結案。 tttt申覆處理或申述查明情由"};
String[] str3 = new String[]{"三、CI-101(金融商品買賣作業):詳察具復之","總公司>董事長室回覆:申覆處理或申述查明情由與","擬辦: 本案擬結案。 31231"};
String[] str4 = new String[]{"四、標題詳察具復之 ","總公司>董事長室回覆:申覆處理或申述查明情由與","擬辦: 本案擬結案。擬辦"};
String[] str5 = new String[]{"五、12312","擬辦: 本案擬結案。碁碁碁珮許功蓋","擬辦: 本案擬結案。 31231"};
dataList.add(str1);
dataList.add(str2);
dataList.add(str3);
dataList.add(str4);
dataList.add(str5);
word.openWord(true); // 設定word開啟顯示
word.openDocument(templateFile);// 建立文件內容
word.replace("@projectName@", "jacob项目测试");
word.replaceTable(word.select(), tableName, dataList);
word.find(word.select(), "#插入文件测试#");
word.insertFile(word.select(), rsFile);
word.insertFile( rsFile);
word.find(word.select(), "[项目背景]");
word.moveDown(word.select(), 1);
word.insertFile( rsFile);
word.saveFileAs(otFile);
}
catch(Exception ex)
{
ex.printStackTrace();
}
finally
{
word.closeDocument();
word.closeWord();
}
}
}
- jacob-1.14.3.zip (370 KB)
- 下载次数: 188
相关推荐
### Java操作Word:Jacob(方法解析+环境配置) #### Jacob简介 Jacob是一个开源的Java-COM桥接工具,它允许Java程序与Windows平台上的COM组件进行交互。这意味着开发者可以通过Java来控制诸如Microsoft Word、...
在处理文档操作时,Java提供了一些库来实现高级功能,比如在Word文档中添加图片水印。本篇将深入探讨如何使用Java和两个特定的库——iTextPDF与Jacob——来实现这一目标。 首先,iTextPDF是一个开源的Java库,专门...
因此,Java2word很可能依赖于Jacob来与Word进行交互。 Jacob库在Java应用中起到了关键作用,它使得开发者能够利用Java编程语言操控Word的复杂功能,如样式设置、表格插入、图片嵌入等。在更新的Java2word版本中,...
总的来说,Java操作Word-Jacob是一种有效的技术,特别适合那些需要在Java环境中处理大量Word文档或者需要对Word文档进行深度定制的应用场景。不过,需要根据项目需求和目标平台来权衡选择哪种方法最合适。
Jacob库为Java开发者提供了一个与Microsoft Office交互的解决方案,允许在Java应用程序中操纵Word文档。Jacob库实际上是Java和COM(Component Object Model)之间的桥梁,使得Java能够调用Windows平台上的Office API...
读取word文件的内容,并将内容返回为String类型!
java操作word 超简单实用:第一步: 引入包jacob.jar 第二步:参考工具类MsWordTool.java 含概基本WORD 所有操作方法 【特别难点】解决实例: 1)word书签内容替换后,书签会丢失问题 2)word定点批量插入图片...
此外,由于JACOB直接操作COM对象,所以性能可能不如其他专门处理Office文档的Java库,如Apache POI,但在某些场景下,JACOB提供了直接控制Word的强大能力,对于简单的打印任务是一个实用的选择。 总的来说,Java...
本篇将深入探讨如何利用Java处理Word文件,特别是基于模板进行操作。 首先,我们需要引入一个名为Apache POI的库,这是一个强大的API,专门用于读写Microsoft Office格式的文件,包括Word(.doc和.docx)。在Java中...
java Jacob完美实现word添加图片水印(内附源码及jar包)。 公司最近让搞Word文档添加水印,所有下载的文档需要添加公司印章,搞了好多天才实现,利用Jacob完美实现word添加图片水印(注意需要把dll文件放到jdk的bin...
通过Jacob,我们可以在Java程序中操作这些Office应用,实现对Word文档的各种处理,包括读取、修改和转换。 在“word转图片”的过程中,Java程序可以使用Jacob打开Word文档,然后通过截屏或者利用Word的API将文档...
在编程实践中,通过JACOB调用Word宏的代码,可以将Word文档处理的自动化操作集成到Java应用中。这不仅适用于文档自动生成,还适用于与Word交互的多种自动化任务,例如邮件合并、文档内容更新等。开发者应熟练掌握...
通过Java2Word和Jacob,开发者可以轻松地在Java应用中实现Word文档的生成,这对于企业级应用来说尤其有用,比如报表系统、合同管理系统、知识库等,可以大大提高工作效率,减少手动操作。不过,需要注意的是,由于...
在Java编程环境中,读取和处理Word文档通常涉及到使用第三方库,因为Java标准库并不直接支持Word文件的操作。本主题将深入探讨如何利用给定的`itextpdf-5.5.9.jar`和`jacob.jar`这两个库来实现Java读取Word文档页数...
总的来说,这个项目展示了如何利用Jacob库在Java中自动化处理Word文档,通过模板和数据填充,可以大大提高文档生成的效率。对于需要批量生成定制化Word文档的企业,这样的解决方案极具价值。同时,通过阅读源代码和...
Jacob库弥补了这个不足,使得Java程序员能够利用COM接口与Word进行通信,实现复杂的文档处理任务。 Jacob库的工作原理是通过JNI(Java Native Interface)将Java代码与Windows平台的COM接口连接起来。这意味着,...
以上步骤概括了使用JACOB.jar库在Java中打印Word文档的基本流程。实际开发时,可能需要根据具体需求进行更复杂的操作,如添加页眉页脚、处理异常、自动化处理多个文档等。同时,由于JACOB是与Windows系统紧密关联的...
本文提供关于jacob配置的dll文件,java2word的运行安装文件,jacob和java2word整合jar包 ckedtior网页编辑器需要用的jar,以及使用整合后的jar对word进行插入图片、带格式文字段落、和导出word功能源码
总的来说,通过Java和Jacob库的结合,我们可以实现批处理Word文档转换为txt,这对于大量文档处理的场景非常实用。但这种方法受限于Windows环境和Microsoft Office的安装,对于跨平台的应用可能不是最佳选择。在实际...
在Java中,可以使用第三方库如Apache POI处理Word文档,但要将Word转换为PDF,通常需要借助像JACOB这样的库。JACOB(Java COM Bridge)是一个Java到COM桥接器,它允许Java程序调用COM组件,从而能够利用Microsoft ...