`
hoopy1987
  • 浏览: 10418 次
  • 性别: Icon_minigender_1
  • 来自: 南京
社区版块
存档分类
最新评论

Jacob替换Word标签及转成Html等简单应用

阅读更多

此内容仅支持Window系统 jacob-1.15-M4-x86.dll

 

一、一般应用于使用Word模版中的标签进行内容替换

 

 

String templetPath = ""; //模版文件
String otPath = ""; //保存文件
GF_JacobUtil word = new GF_JacobUtil();
try {
    //是否显示打开word
	word.openWord(false);
    //打开模版文件
	word.openDocument(templetPath);
    //替换书签内容
	word.replaceBookMark("Prj_Name", "项目");
    //保存到path
	word.saveFileAs(otPath );
} catch (Exception ex) {
	ex.printStackTrace();
} finally {
    //关闭Word
	word.closeDocument();
	word.closeWord();
}

    这个是网上前人总结的一个工具类,稍微修改

 

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"); // 游標往下一行
	}
	
	/**
	 * 换行
	 */
	public void insertEnter(){
		Dispatch.call(selection, "TypeText", "\r\n");
	}
	
	/**
	 * 写入文字
	 */
	public void insertContent(String content){
		Dispatch.call(selection, "TypeText", content);
	}

	/**
	 * 合併表格
	 * 
	 * @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();
	}
	
	public void acceptAllChanges(){
		Dispatch oWordBasic = (Dispatch) Dispatch.call(MsWordApp, "WordBasic").getDispatch();
		Dispatch.call(oWordBasic, "AcceptAllChangesInDoc"); 
	}
	
	public void wordToHtml(String inPath,String fileName){
		//MsWordApp.setProperty("Visible", new Variant(false));// 设置word不可见
		String htmlPath = inPath + fileName;
		Object doc1 = MsWordApp.getProperty("Documents").toDispatch();
		Object doc2 = Dispatch.invoke(
				(Dispatch) doc1,
				"Open",
				Dispatch.Method,
				new Object[] { inPath + fileName + ".doc", new Variant(false),
						new Variant(true) }, new int[1]).toDispatch();// 打开word文件

		Dispatch.invoke((Dispatch) doc2, "SaveAs", Dispatch.Method, new Object[] {
				htmlPath, new Variant(8) }, new int[1]);
		//Variant f = new Variant(false);
		//Dispatch.call((Dispatch)doc2, "Close", f); // 关闭
	}
	
	
	/**
	 * 另存檔案
	 * 
	 * @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 void replaceBookMark(String bookMarkKey,String value) {
		Dispatch activeDocument = MsWordApp.getProperty("ActiveDocument").toDispatch(); 
		Dispatch bookMarks = MsWordApp.call(activeDocument, "Bookmarks")
				.toDispatch();
		boolean bookMarkExist1 = Dispatch.call(bookMarks, "Exists",
				bookMarkKey).toBoolean();
		if (bookMarkExist1 == true) {
			System.out.println("已找到书签 " + bookMarkKey);
			Dispatch rangeItem = Dispatch.call(bookMarks, "Item", bookMarkKey)
					.toDispatch();
			Dispatch range = Dispatch.call(rangeItem, "Range").toDispatch();
			
			String bookMarkValue = Dispatch.get(range, "Text").toString();
			
			if (bookMarkValue != null) {
				Dispatch.put(range,"Text",new Variant(value));
			}
		} else {
			System.out.println("指定的书签不存在 ");
		}
	}
	
	public void findBookMark(String bookMarkKey) {
		Dispatch activeDocument = MsWordApp.getProperty("ActiveDocument").toDispatch(); 
		Dispatch bookMarks = MsWordApp.call(activeDocument, "Bookmarks")
				.toDispatch();
		boolean bookMarkExist1 = Dispatch.call(bookMarks, "Exists",
				bookMarkKey).toBoolean();
		if (bookMarkExist1 == true) {
			System.out.println("已找到书签 " + bookMarkKey);
			Dispatch rangeItem = Dispatch.call(bookMarks, "Item", bookMarkKey)
					.toDispatch();
			Dispatch range = Dispatch.call(rangeItem, "Range").toDispatch();
			
			String bookMarkValue = Dispatch.get(range, "Text").toString();
//			
			if (bookMarkValue != null) {
				Dispatch.call(range,"Select"); 
			}
		} else {
			System.out.println("指定的书签不存在 ");
		}
	}

}
 

二、将doc保存成html

 

 

package com.njusoft.utils;

import com.jacob.activeX.ActiveXComponent;
import com.jacob.com.Dispatch;
import com.jacob.com.Variant;

public class WordToHtml {

	public WordToHtml(String inPath, String outPath, String fileName) {
		ActiveXComponent app = new ActiveXComponent("Word.Application");// 打开word
		String htmlPath = outPath + "/" + fileName;// html文件路径
		try {
			app.setProperty("Visible", new Variant(false));// 设置word不可见

			Object doc1 = app.getProperty("Documents").toDispatch();
			Object doc2 = Dispatch.invoke(
					(Dispatch) doc1,
					"Open",
					Dispatch.Method,
					new Object[] { inPath + "/" + fileName + ".doc", new Variant(false),
							new Variant(true) }, new int[1]).toDispatch();// 打开word文件

			Dispatch.invoke((Dispatch) doc2, "SaveAs", Dispatch.Method, new Object[] {
					htmlPath, new Variant(8) }, new int[1]);
			// 作为html格式保存到临时文件

			Variant f = new Variant(false);
			Dispatch.call((Dispatch)doc2, "Close", f); // 关闭
		} catch (Exception e) {
			e.printStackTrace();
		} finally {
			app.invoke("Quit", new Variant[] {});
		}

	}

}
 

三、常见的一个问题

    在普通的java项目中一般只需要导入java包就OK,但是在Web项目中可能会出现找不到工具类等问题

   解决办法:将dll文件放入java.library.path目录下即可

System.out.println(System.getProperty("java.library.path"));

分享到:
评论

相关推荐

    java开源包1

    J2C 将 Java 代码转成 C++ 代码,这是源码级别的转换,输出的 C++ 代码是有效的代码。 OSGi 分布式通讯组件 R-OSGi R-OSGi 是一套适用于任意满足 OSGi 架构的分布式通讯组件。它以 jar 的形式发布,部署容易,使用...

    java开源包11

    J2C 将 Java 代码转成 C++ 代码,这是源码级别的转换,输出的 C++ 代码是有效的代码。 OSGi 分布式通讯组件 R-OSGi R-OSGi 是一套适用于任意满足 OSGi 架构的分布式通讯组件。它以 jar 的形式发布,部署容易,使用...

    java开源包2

    J2C 将 Java 代码转成 C++ 代码,这是源码级别的转换,输出的 C++ 代码是有效的代码。 OSGi 分布式通讯组件 R-OSGi R-OSGi 是一套适用于任意满足 OSGi 架构的分布式通讯组件。它以 jar 的形式发布,部署容易,使用...

    java开源包3

    J2C 将 Java 代码转成 C++ 代码,这是源码级别的转换,输出的 C++ 代码是有效的代码。 OSGi 分布式通讯组件 R-OSGi R-OSGi 是一套适用于任意满足 OSGi 架构的分布式通讯组件。它以 jar 的形式发布,部署容易,使用...

    java开源包6

    J2C 将 Java 代码转成 C++ 代码,这是源码级别的转换,输出的 C++ 代码是有效的代码。 OSGi 分布式通讯组件 R-OSGi R-OSGi 是一套适用于任意满足 OSGi 架构的分布式通讯组件。它以 jar 的形式发布,部署容易,使用...

    java开源包5

    J2C 将 Java 代码转成 C++ 代码,这是源码级别的转换,输出的 C++ 代码是有效的代码。 OSGi 分布式通讯组件 R-OSGi R-OSGi 是一套适用于任意满足 OSGi 架构的分布式通讯组件。它以 jar 的形式发布,部署容易,使用...

    java开源包10

    J2C 将 Java 代码转成 C++ 代码,这是源码级别的转换,输出的 C++ 代码是有效的代码。 OSGi 分布式通讯组件 R-OSGi R-OSGi 是一套适用于任意满足 OSGi 架构的分布式通讯组件。它以 jar 的形式发布,部署容易,使用...

    java开源包4

    J2C 将 Java 代码转成 C++ 代码,这是源码级别的转换,输出的 C++ 代码是有效的代码。 OSGi 分布式通讯组件 R-OSGi R-OSGi 是一套适用于任意满足 OSGi 架构的分布式通讯组件。它以 jar 的形式发布,部署容易,使用...

    java开源包8

    J2C 将 Java 代码转成 C++ 代码,这是源码级别的转换,输出的 C++ 代码是有效的代码。 OSGi 分布式通讯组件 R-OSGi R-OSGi 是一套适用于任意满足 OSGi 架构的分布式通讯组件。它以 jar 的形式发布,部署容易,使用...

    java开源包7

    J2C 将 Java 代码转成 C++ 代码,这是源码级别的转换,输出的 C++ 代码是有效的代码。 OSGi 分布式通讯组件 R-OSGi R-OSGi 是一套适用于任意满足 OSGi 架构的分布式通讯组件。它以 jar 的形式发布,部署容易,使用...

    java开源包9

    J2C 将 Java 代码转成 C++ 代码,这是源码级别的转换,输出的 C++ 代码是有效的代码。 OSGi 分布式通讯组件 R-OSGi R-OSGi 是一套适用于任意满足 OSGi 架构的分布式通讯组件。它以 jar 的形式发布,部署容易,使用...

    java开源包101

    J2C 将 Java 代码转成 C++ 代码,这是源码级别的转换,输出的 C++ 代码是有效的代码。 OSGi 分布式通讯组件 R-OSGi R-OSGi 是一套适用于任意满足 OSGi 架构的分布式通讯组件。它以 jar 的形式发布,部署容易,使用...

    Java资源包01

    J2C 将 Java 代码转成 C++ 代码,这是源码级别的转换,输出的 C++ 代码是有效的代码。 OSGi 分布式通讯组件 R-OSGi R-OSGi 是一套适用于任意满足 OSGi 架构的分布式通讯组件。它以 jar 的形式发布,部署容易,使用...

Global site tag (gtag.js) - Google Analytics