- 浏览: 84753 次
- 性别:
- 来自: 广州
文章分类
最新评论
-
beichen35:
您好,如何将request注入进去呢?
jcaptcha集群时验证码不能验证的问题 -
zhengzili813:
楼主可以共享下参考么,邮箱276032337@qq.com 谢 ...
flex表单设计器2 -
八岭书生:
你这个文件夹树形结构是怎么实现的啊 我想弄一个加载本地文件夹的 ...
show下我的网盘 类windows文件管理 -
heiheizi:
您好,您可以将您做的表单设计器发一个给我吗?heiheizi@ ...
SQL在线查询设计器2 -
heiheizi:
博主:你好! 对你的SQL在线查询设计器非常感兴趣, ...
SQL在线查询设计器2
jacob使用
- 博客分类:
- java
提取word文中的关键字信息,替换模板值,经研究采用word书签。
package com.dzf.core.util; import java.util.HashMap; import java.util.List; import java.util.Map; import com.jacob.activeX.ActiveXComponent; import com.jacob.com.ComThread; import com.jacob.com.Dispatch; import com.jacob.com.Variant; /** * @author dzf <a href="mailto:280160522@qq.com">280160522@qq.com</a> */ public class 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 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"); } /** * 保存word为html * @param inPath * @param fileName */ public void wordToHtml(String inPath,String fileName){ 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]); } /** * 另存档案 * * @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(); } /** * 替换指定书签所在的值 * @param bookMarkKey * @param value */ 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).getBoolean();; 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 Map<String,Dispatch> getBookMarkDispatchs(){ Map<String,Dispatch> bookMarkDispatchs = new HashMap<String,Dispatch>(); Dispatch activeDocument = MsWordApp.getProperty("ActiveDocument").toDispatch(); Dispatch bookMarks = MsWordApp.call(activeDocument, "Bookmarks").toDispatch(); int count =Integer.parseInt(Dispatch.get(bookMarks, "Count").toString()); for (int i = 0; i < count; i++) { Dispatch bookMark = Dispatch.call(bookMarks, "Item", new Variant(i + 1)).toDispatch(); bookMarkDispatchs.put(Dispatch.call(bookMark, "Name").toString(),bookMark); } return bookMarkDispatchs; } /** * 得到书签的值 * @param bookMark */ public String getBookMarkValue(Dispatch bookMark){ Dispatch range = Dispatch.call(bookMark, "Range").toDispatch(); return Dispatch.get(range, "text").toString(); } /** * 得到书签的第一个表格 * @param bookMark * @return */ public Dispatch getTableFromBookMark(Dispatch bookMark){ return this.getTableFromBookMark(bookMark, 1); } /** * 得到指定书签的第几个表格 * @param bookMark * @param tableIndex * @return */ public Dispatch getTableFromBookMark(Dispatch bookMark,int tableIndex){ Dispatch range = Dispatch.call(bookMark, "Range").toDispatch(); Dispatch tables=Dispatch.get(range, "Tables").toDispatch(); Dispatch table = Dispatch.call(tables, "Item", new Variant(tableIndex)).toDispatch(); return table; } /** * 根据书签得到 * @param bookMarkKey */ public String findBookMark(String bookMarkKey) { Dispatch activeDocument = MsWordApp.getProperty("ActiveDocument").toDispatch(); Dispatch bookMarks = MsWordApp.call(activeDocument, "Bookmarks").toDispatch(); boolean bookMarkExist = Dispatch.call(bookMarks, "Exists",bookMarkKey).getBoolean(); if (bookMarkExist == 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(); return bookMarkValue; } return null; } }
发表评论
-
HTML我帮您打造微信小程序web可视化开发者工具
2017-03-08 20:41 830HTML我帮您WEBAPP在线可 ... -
SQL在线查询设计器2
2013-02-20 09:20 1217在前人的基础上。进行了扩展。前端用extjs,后端有jav ... -
java与XML文件的读写
2008-04-28 10:49 954DOM 是 Document Object Model ... -
Tomcat 的数据库连接池设置与应用
2008-04-28 10:53 823Tomcat 的数据库连接池设置与应用 ... -
时间处理
2008-05-05 11:43 890首先写了一个公用的转换帮助类 package ... -
读写文件使用
2008-06-18 10:10 792package com.dzf.file; im ...
相关推荐
开发语言:Java JDK版本:JDK1.8(或11) 服务器:tomcat 数据库:mysql 5.6/5.7(或8.0) 数据库工具:Navicat 开发软件:idea 依赖管理包:Maven 代码+数据库保证完整可用,可提供远程调试并指导运行服务(额外付费)~ 如果对系统的中的某些部分感到不合适可提供修改服务,比如题目、界面、功能等等... 声明: 1.项目已经调试过,完美运行 2.需要远程帮忙部署项目,需要额外付费 3.本项目有演示视频,如果需要观看,请联系我 4.调试过程中可帮忙安装IDEA,eclipse,MySQL,JDK,Tomcat等软件 重点: 需要其他Java源码联系我,更多源码任你选,你想要的源码我都有! 需要加v19306446185
数学模型算法
设计.zip
Java SSM项目是一种使用Java语言和SSM框架(Spring + Spring MVC + MyBatis)开发的Web应用程序。SSM是一种常用的Java开发框架组合,它结合了Spring框架、Spring MVC框架和MyBatis框架的优点,能够快速构建可靠、高效的企业级应用。 1. Spring框架:Spring是一个轻量级的Java开发框架,提供了丰富的功能和模块,用于开发企业级应用。它包括IoC(Inverse of Control,控制反转)容器、AOP(Aspect-Oriented Programming,面向切面编程)等特性,可以简化开发过程、提高代码的可维护性和可测试性。 2. Spring MVC框架:Spring MVC是基于Spring框架的Web框架,用于开发Web应用程序。它采用MVC(Model-View-Controller,模型-视图-控制器)的架构模式,将应用程序分为模型层、视图层和控制器层,提供了处理请求、渲染视图和管理流程的功能。 3. MyBatis框架:MyBatis是一个持久层框架,用于与数据库进行交互。它提供了一种将数据库操作与Java对象映射起来的方式,避免了手动编写繁琐的SQL语句,并提供了事务管理和缓存等功能,简化了数据库访问的过程
【微信小程序毕业设计】书店系统开发项目(源码+演示视频+说明).rar 【项目技术】 微信小程序开发工具+java后端+mysql 【演示视频-编号:246】 https://pan.quark.cn/s/cb634e7c02b5 【实现功能】 用户信息管理,图书信息管理,图书类型管理,图书留言管理,论坛信息管理等
提供的源码资源涵盖了Java应用等多个领域,每个领域都包含了丰富的实例和项目。这些源码都是基于各自平台的最新技术和标准编写,确保了在对应环境下能够无缝运行。同时,源码中配备了详细的注释和文档,帮助用户快速理解代码结构和实现逻辑。 适用人群: 适合毕业设计、课程设计作业。这些源码资源特别适合大学生群体。无论你是计算机相关专业的学生,还是对其他领域编程感兴趣的学生,这些资源都能为你提供宝贵的学习和实践机会。通过学习和运行这些源码,你可以掌握各平台开发的基础知识,提升编程能力和项目实战经验。 使用场景及目标: 在学习阶段,你可以利用这些源码资源进行课程实践、课外项目或毕业设计。通过分析和运行源码,你将深入了解各平台开发的技术细节和最佳实践,逐步培养起自己的项目开发和问题解决能力。此外,在求职或创业过程中,具备跨平台开发能力的大学生将更具竞争力。 其他说明: 为了确保源码资源的可运行性和易用性,特别注意了以下几点:首先,每份源码都提供了详细的运行环境和依赖说明,确保用户能够轻松搭建起开发环境;其次,源码中的注释和文档都非常完善,方便用户快速上手和理解代码;最后,我会定期更新这些源码资源,以适应各平台技术的最新发展和市场需求。 所有源码均经过严格测试,可以直接运行,可以放心下载使用。有任何使用问题欢迎随时与博主沟通,第一时间进行解答!
Java SSM项目是一种使用Java语言和SSM框架(Spring + Spring MVC + MyBatis)开发的Web应用程序。SSM是一种常用的Java开发框架组合,它结合了Spring框架、Spring MVC框架和MyBatis框架的优点,能够快速构建可靠、高效的企业级应用。 1. Spring框架:Spring是一个轻量级的Java开发框架,提供了丰富的功能和模块,用于开发企业级应用。它包括IoC(Inverse of Control,控制反转)容器、AOP(Aspect-Oriented Programming,面向切面编程)等特性,可以简化开发过程、提高代码的可维护性和可测试性。 2. Spring MVC框架:Spring MVC是基于Spring框架的Web框架,用于开发Web应用程序。它采用MVC(Model-View-Controller,模型-视图-控制器)的架构模式,将应用程序分为模型层、视图层和控制器层,提供了处理请求、渲染视图和管理流程的功能。 3. MyBatis框架:MyBatis是一个持久层框架,用于与数据库进行交互。它提供了一种将数据库操作与Java对象映射起来的方式,避免了手动编写繁琐的SQL语句,并提供了事务管理和缓存等功能,简化了数据库访问的过程
Java SSM项目是一种使用Java语言和SSM框架(Spring + Spring MVC + MyBatis)开发的Web应用程序。SSM是一种常用的Java开发框架组合,它结合了Spring框架、Spring MVC框架和MyBatis框架的优点,能够快速构建可靠、高效的企业级应用。 1. Spring框架:Spring是一个轻量级的Java开发框架,提供了丰富的功能和模块,用于开发企业级应用。它包括IoC(Inverse of Control,控制反转)容器、AOP(Aspect-Oriented Programming,面向切面编程)等特性,可以简化开发过程、提高代码的可维护性和可测试性。 2. Spring MVC框架:Spring MVC是基于Spring框架的Web框架,用于开发Web应用程序。它采用MVC(Model-View-Controller,模型-视图-控制器)的架构模式,将应用程序分为模型层、视图层和控制器层,提供了处理请求、渲染视图和管理流程的功能。 3. MyBatis框架:MyBatis是一个持久层框架,用于与数据库进行交互。它提供了一种将数据库操作与Java对象映射起来的方式,避免了手动编写繁琐的SQL语句,并提供了事务管理和缓存等功能,简化了数据库访问的过程
决策树, 决策树(Decision Tree)是一种常见的数据挖掘算法,它模仿人类决策过程来预测数据。决策树是一种树形结构,它从根节点开始,分支延伸至叶节点,每个内部节点代表了某个特征的测试,而每个叶节点代表了最终的预测结果。
提供的源码资源涵盖了小程序应用等多个领域,每个领域都包含了丰富的实例和项目。这些源码都是基于各自平台的最新技术和标准编写,确保了在对应环境下能够无缝运行。同时,源码中配备了详细的注释和文档,帮助用户快速理解代码结构和实现逻辑。 适用人群: 适合毕业设计、课程设计作业。这些源码资源特别适合大学生群体。无论你是计算机相关专业的学生,还是对其他领域编程感兴趣的学生,这些资源都能为你提供宝贵的学习和实践机会。通过学习和运行这些源码,你可以掌握各平台开发的基础知识,提升编程能力和项目实战经验。 使用场景及目标: 在学习阶段,你可以利用这些源码资源进行课程实践、课外项目或毕业设计。通过分析和运行源码,你将深入了解各平台开发的技术细节和最佳实践,逐步培养起自己的项目开发和问题解决能力。此外,在求职或创业过程中,具备跨平台开发能力的大学生将更具竞争力。 其他说明: 为了确保源码资源的可运行性和易用性,特别注意了以下几点:首先,每份源码都提供了详细的运行环境和依赖说明,确保用户能够轻松搭建起开发环境;其次,源码中的注释和文档都非常完善,方便用户快速上手和理解代码;最后,我会定期更新这些源码资源,以适应各平台技术的最新发展和市场需求。 所有源码均经过严格测试,可以直接运行,可以放心下载使用。有任何使用问题欢迎随时与博主沟通,第一时间进行解答!
提供的源码资源涵盖了Java应用等多个领域,每个领域都包含了丰富的实例和项目。这些源码都是基于各自平台的最新技术和标准编写,确保了在对应环境下能够无缝运行。同时,源码中配备了详细的注释和文档,帮助用户快速理解代码结构和实现逻辑。 适用人群: 适合毕业设计、课程设计作业。这些源码资源特别适合大学生群体。无论你是计算机相关专业的学生,还是对其他领域编程感兴趣的学生,这些资源都能为你提供宝贵的学习和实践机会。通过学习和运行这些源码,你可以掌握各平台开发的基础知识,提升编程能力和项目实战经验。 使用场景及目标: 在学习阶段,你可以利用这些源码资源进行课程实践、课外项目或毕业设计。通过分析和运行源码,你将深入了解各平台开发的技术细节和最佳实践,逐步培养起自己的项目开发和问题解决能力。此外,在求职或创业过程中,具备跨平台开发能力的大学生将更具竞争力。 其他说明: 为了确保源码资源的可运行性和易用性,特别注意了以下几点:首先,每份源码都提供了详细的运行环境和依赖说明,确保用户能够轻松搭建起开发环境;其次,源码中的注释和文档都非常完善,方便用户快速上手和理解代码;最后,我会定期更新这些源码资源,以适应各平台技术的最新发展和市场需求。 所有源码均经过严格测试,可以直接运行,可以放心下载使用。有任何使用问题欢迎随时与博主沟通,第一时间进行解答!
提供的源码资源涵盖了小程序应用等多个领域,每个领域都包含了丰富的实例和项目。这些源码都是基于各自平台的最新技术和标准编写,确保了在对应环境下能够无缝运行。同时,源码中配备了详细的注释和文档,帮助用户快速理解代码结构和实现逻辑。 适用人群: 适合毕业设计、课程设计作业。这些源码资源特别适合大学生群体。无论你是计算机相关专业的学生,还是对其他领域编程感兴趣的学生,这些资源都能为你提供宝贵的学习和实践机会。通过学习和运行这些源码,你可以掌握各平台开发的基础知识,提升编程能力和项目实战经验。 使用场景及目标: 在学习阶段,你可以利用这些源码资源进行课程实践、课外项目或毕业设计。通过分析和运行源码,你将深入了解各平台开发的技术细节和最佳实践,逐步培养起自己的项目开发和问题解决能力。此外,在求职或创业过程中,具备跨平台开发能力的大学生将更具竞争力。 其他说明: 为了确保源码资源的可运行性和易用性,特别注意了以下几点:首先,每份源码都提供了详细的运行环境和依赖说明,确保用户能够轻松搭建起开发环境;其次,源码中的注释和文档都非常完善,方便用户快速上手和理解代码;最后,我会定期更新这些源码资源,以适应各平台技术的最新发展和市场需求。 所有源码均经过严格测试,可以直接运行,可以放心下载使用。有任何使用问题欢迎随时与博主沟通,第一时间进行解答!
附件是Java网络爬虫源代码的压缩包,文件绿色安全,仅供学习交流使用,欢迎大家下载学习交流!
这里为你收集整理了关于毕业设计、课程设计可参考借鉴的资料一份,质量非常高,如果你投入时间去研究几天相信肯定对你有很大的帮助。到时候你会回来感谢我的。 本资源是经过本地编译测试、可打开、可运行的项目、文件或源码,可以用于毕业设计、课程设计的应用、参考和学习需求,请放心下载。 祝愿你在这个毕业设计项目中取得巨大进步,顺利毕业! 但还需强调一下,这些项目源码仅供学习和研究之用。在使用这些资源时,请务必遵守学术诚信原则和相关法律法规,不得将其用于任何商业目的或侵犯他人权益的行为。对于任何因使用本资源而导致的问题,包括但不限于数据丢失、系统崩溃或安全漏洞,风险自担哦!
基于JSP毕业设计-+Struct+MySql基于BBS管理系统设计与实现(源代码+论文+中英资料+开题报告+答辩PPT).zip 现今的社会是一个信息飞速发达的社会,其中在信息的交流当中,互联网占据着一个非常重要的位置。人们可以通过在互联网上收到最新的消息,也可以通过互联网进行信息的交流。而论坛就是大家进行信息交流的其中一个渠道。 论坛的概念:论坛(BBS)是Bulletin-Board-System的缩写,即电子公告栏。它是一种在Internet网上开放的信息服务系统,通过论坛用户可以方便的实现信息的交换和文件的共享。 本文主要完成了基于JSP技术的信息交流论坛的设计和实现,主要实现了客户端和服务器端的动态交互。该系统包含六个模块:论坛用户登陆注册模块,论坛账户信息模块,论坛文章发布模块,公告/制度模块,版块管理模块,信息管理模块。论文详细描述了模块的结构、功能以及具体设计过程。系统采用了JSP技术以及JavaBeans组件技术和JDBC技术实现。 关键词:JSP,BBS,MYSQL,JavaBeans,系统设计
【课件PPT】华为干部赋能手册gl.pptx
大数据技术指的是用于处理和分析大规模数据集的技术和工具。以下是一些常见的大数据技术和工具: Hadoop:Apache Hadoop是一个用于分布式存储和处理大规模数据的开源框架。它包括Hadoop Distributed File System(HDFS)用于数据存储和MapReduce用于数据处理。 Spark:Apache Spark是一个快速、通用的集群计算系统,提供了比MapReduce更快的数据处理能力。它支持内存计算和更多复杂的数据处理流程。 NoSQL数据库:NoSQL数据库(如MongoDB、Cassandra等)则更适用于处理这类数据。 数据仓库:数据仓库是一个用于集成和分析大规模数据的存储系统,一些知名的数据仓库包括Snowflake、Amazon Redshift等。 数据湖:数据湖是一个存储结构化和非结构化数据的存储池,用于支持数据分析和机器学习应用。 机器学习:大数据技术也广泛应用于机器学习领域,支持大规模数据的模型训练和预测分析。 流式处理:针对实时数据处理需求,流式处理技术(如Apache Kafka、Apache Flink)可以实时。
【微信小程序毕业设计】懒人美食帮系统开发项目(源码+演示视频+说明).rar 【项目技术】 微信小程序开发工具+java后端+mysql 【演示视频-编号:290】 https://pan.quark.cn/s/cb634e7c02b5 【实现功能】 本系统实现管理员和用户、商家、配送员四个角色的功能。用户主要在微信端操作,内容有菜品信息,用户可以在线点餐和管理订单信息以及查看配送情况。商家可以发布菜品和管理订单、查看配送情况。管理员可以审核菜品以及管理订单等。配送员可以接单完成配送。
Node.js,简称Node,是一个开源且跨平台的JavaScript运行时环境,它允许在浏览器外运行JavaScript代码。Node.js于2009年由Ryan Dahl创立,旨在创建高性能的Web服务器和网络应用程序。它基于Google Chrome的V8 JavaScript引擎,可以在Windows、Linux、Unix、Mac OS X等操作系统上运行。 Node.js的特点之一是事件驱动和非阻塞I/O模型,这使得它非常适合处理大量并发连接,从而在构建实时应用程序如在线游戏、聊天应用以及实时通讯服务时表现卓越。此外,Node.js使用了模块化的架构,通过npm(Node package manager,Node包管理器),社区成员可以共享和复用代码,极大地促进了Node.js生态系统的发展和扩张。 Node.js不仅用于服务器端开发。随着技术的发展,它也被用于构建工具链、开发桌面应用程序、物联网设备等。Node.js能够处理文件系统、操作数据库、处理网络请求等,因此,开发者可以用JavaScript编写全栈应用程序,这一点大大提高了开发效率和便捷性。 在实践中,许多大型企业和组织已经采用Node.js作为其Web应用程序的开发平台,如Netflix、PayPal和Walmart等。它们利用Node.js提高了应用性能,简化了开发流程,并且能更快地响应市场需求。
模型算法模拟退火资料合集含: satools 模拟退火工具箱satools 模拟退火算法模拟退火算法的matlab示例模拟退火算法论文 违传退火进化算法,rar直接搜索算法模拟退火算法(MATLAB实现)模拟退火算法(新)模拟退火算法 模拟退火算法及禁忌搜索算法的matlab...模拟退火算法求解TSP问题Matlab源码模拟退火算法源程序 模拟退火算法在指数曲线拟合中的应用数学中国针对美赛培训汇总(1)选传算法解非线性方程组的Matlab程序元胞自动机与Matlab