POI往word模板中写入数据
转:
POI的XWPFDocument和XWPFTemplate两种方法往word模板中填充数据
- import java.io.ByteArrayOutputStream;
- import java.io.File;
- import java.io.FileInputStream;
- import java.io.FileOutputStream;
- import java.io.IOException;
- import java.io.InputStream;
- import java.io.OutputStream;
- import java.util.HashMap;
- import java.util.Iterator;
- import java.util.List;
- import java.util.Map;
- import java.util.Map.Entry;
- import java.util.regex.Matcher;
- import java.util.regex.Pattern;
- import org.apache.poi.POIXMLProperties.CoreProperties;
- import org.apache.poi.hwpf.HWPFDocument;
- import org.apache.poi.hwpf.usermodel.Range;
- import org.apache.poi.xwpf.extractor.XWPFWordExtractor;
- import org.apache.poi.xwpf.usermodel.XWPFDocument;
- import org.apache.poi.xwpf.usermodel.XWPFParagraph;
- import org.apache.poi.xwpf.usermodel.XWPFRun;
- import org.apache.poi.xwpf.usermodel.XWPFTable;
- import org.apache.poi.xwpf.usermodel.XWPFTableCell;
- import org.apache.poi.xwpf.usermodel.XWPFTableRow;
- import com.deepoove.poi.XWPFTemplate;
- import com.deepoove.poi.data.PictureRenderData;
- /**
- * @author Admin
- *
- */
- public class WriteWordUtil {
- public void writeDocx(String path, Map<String, String> map) throws Exception {
- InputStream is = new FileInputStream(path);
- XWPFDocument doc = new XWPFDocument(is);
- // XWPFWordExtractor extractor = new XWPFWordExtractor(doc) ;
- // String text = extractor.getText();
- // System.out.println(text);
- // CoreProperties coreProps = extractor.getCoreProperties();
- // this.printCoreProperties(coreProps);
- // this.close(is);
- }
- /**
- * 替换段落里面的变量
- *
- * @param doc
- * 要替换的文档
- * @param params
- * 参数
- */
- private void replaceInPara(XWPFDocument doc, Map<String, Object> params) {
- Iterator<XWPFParagraph> iterator = doc.getParagraphsIterator();
- XWPFParagraph para;
- while (iterator.hasNext()) {
- para = iterator.next();
- this.replaceInPara(para, params);
- }
- }
- /**
- * 替换段落里面的变量
- *
- * @param para
- * 要替换的段落
- * @param params
- * 参数
- */
- private void replaceInPara(XWPFParagraph para, Map<String, Object> params) {
- List<XWPFRun> runs;
- Matcher matcher;
- if (this.matcher(para.getParagraphText()).find()) {
- runs = para.getRuns();
- for (int i = 0; i < runs.size(); i++) {
- XWPFRun run = runs.get(i);
- String runText = run.toString();
- matcher = this.matcher(runText);
- if (matcher.find()) {
- while ((matcher = this.matcher(runText)).find()) {
- runText = matcher.replaceFirst(String.valueOf(params.get(matcher.group(1))));
- }
- // 直接调用XWPFRun的setText()方法设置文本时,在底层会重新创建一个XWPFRun,把文本附加在当前文本后面,
- // 所以我们不能直接设值,需要先删除当前run,然后再自己手动插入一个新的run。
- para.removeRun(i);
- if(runText.equals("null")){
- runText="";
- }
- para.insertNewRun(i).setText(runText);
- }
- }
- }
- }
- /**
- * 替换表格里面的变量
- *
- * @param doc
- * 要替换的文档
- * @param params
- * 参数
- */
- private void replaceInTable(XWPFDocument doc, Map<String, Object> params) {
- Iterator<XWPFTable> iterator = doc.getTablesIterator();
- XWPFTable table;
- List<XWPFTableRow> rows;
- List<XWPFTableCell> cells;
- List<XWPFParagraph> paras;
- while (iterator.hasNext()) {
- table = iterator.next();
- rows = table.getRows();
- for (XWPFTableRow row : rows) {
- cells = row.getTableCells();
- for (XWPFTableCell cell : cells) {
- String cellTextString = cell.getText();
- for (Entry<String, Object> e : params.entrySet()) {
- if (cellTextString.contains("${"+e.getKey()+"}"))
- cellTextString = cellTextString.replace("${"+e.getKey()+"}", e.getValue().toString());
- }
- cell.removeParagraph(0);
- if(cellTextString.contains("${") && cellTextString.contains("}")){
- cellTextString = "";
- }
- cell.setText(cellTextString);
- // paras = cell.getParagraphs();
- // for (XWPFParagraph para : paras) {
- // this.replaceInPara(para, params);
- // }
- }
- }
- }
- }
- /**
- * 正则匹配字符串
- *
- * @param str
- * @return
- */
- private Matcher matcher(String str) {
- Pattern pattern = Pattern.compile("\\$\\{(.+?)\\}", Pattern.CASE_INSENSITIVE);
- Matcher matcher = pattern.matcher(str);
- return matcher;
- }
- /**
- * 关闭输入流
- *
- * @param is
- */
- private void close(InputStream is) {
- if (is != null) {
- try {
- is.close();
- } catch (IOException e) {
- e.printStackTrace();
- }
- }
- }
- /**
- * 关闭输出流
- *
- * @param os
- */
- private void close(OutputStream os) {
- if (os != null) {
- try {
- os.close();
- } catch (IOException e) {
- e.printStackTrace();
- }
- }
- }
- /**
- * 输出CoreProperties信息
- *
- * @param coreProps
- */
- private void printCoreProperties(CoreProperties coreProps) {
- System.out.println(coreProps.getCategory()); // 分类
- System.out.println(coreProps.getCreator()); // 创建者
- System.out.println(coreProps.getCreated()); // 创建时间
- System.out.println(coreProps.getTitle()); // 标题
- }
- /**
- * word占位用${object}有缺陷不能填充图片
- * @param filePath
- * @param params
- * @throws Exception
- */
- public static String templateWrite(String filePath, Map<String, Object> params,String outFilePath)throws Exception{
- InputStream is = new FileInputStream(filePath);
- WriteWordUtil writeWordUtil = new WriteWordUtil();
- XWPFDocument doc = new XWPFDocument(is);
- // 替换段落里面的变量
- writeWordUtil.replaceInPara(doc, params);
- // 替换表格里面的变量
- writeWordUtil.replaceInTable(doc, params);
- OutputStream os = new FileOutputStream(outFilePath);
- doc.write(os);
- writeWordUtil.close(os);
- writeWordUtil.close(is);
- os.flush();
- os.close();
- return "";
- }
- /**
- * word占位用{{object}}比较完美可以填充图片
- * @param filePath
- * @param params
- * @param outFilePath
- * @return
- * @throws Exception
- */
- public static String templateWrite2(String filePath, Map<String, Object> params,String outFilePath)throws Exception{
- XWPFTemplate template = XWPFTemplate.compile(filePath).render(params);
- FileOutputStream out = new FileOutputStream(outFilePath);
- template.write(out);
- out.flush();
- out.close();
- template.close();
- return "";
- }
- public static void main(String[] args) throws Exception {
- Map<String, Object> params = new HashMap<String, Object>();
- params.put("JSDWMC", "项目1\r\na");//
- params.put("XMMC", "项目2\r\nb");//
- params.put("1", "1");//
- params.put("2", "2");//
- params.put("object1", "o1");//
- params.put("object2", "o2");//
- params.put("localPicture", new PictureRenderData(120, 120, "D:\\A.png"));
- templateWrite("D:\\template\\1.docx", params, "D:\\template\\5.docx");
- templateWrite2("D:\\2.docx", params, "D:\\template\\7.docx");
- }
- }
用到的jar包
poi-3.17.jar
poi-examples-3.17.jar
poi-excelant-3.17.jar
poi-ooxml-3.17.jar
poi-ooxml-schemas-3.17.jar
poi-scratchpad-3.17.jar
poi-tl.jar
jar下载:下载地址
POI往word模板中写入数据的更多相关文章
- 向Word模板中填充数据
现在有这样的需求,给Word文档的指定位置填充上特定数据,例如我们有一个终端,用来打印员工的薪资证明,对于一个公司来说,他的薪资证明模板是固定的,变化的地方是员工姓名,部门,职位等.我们只需要将这些指 ...
- [转载]java向word模板中填充数据(总结)
使用过PageOffice动态生成word文档的人都知道,PageOffice可以给word文档的指定位置进行填充,这里我们所说的指定位置在PageOffice的专业术语里面有两个概念,一个叫做数据区 ...
- [原创]java向word模板中填充数据(总结)
使用过PageOffice动态生成word文档的人都知道,PageOffice可以给word文档的指定位置进行填充,这里我们所说的指定位置在PageOffice的专业术语里面有两个概念,一个叫做数据区 ...
- 将excel中的数据填入word模板中-VBA
首先将word模板中需要填写excel中数据的空白处用自己独特的字符串标记,比如 数据001 什么的.如下图: 这样,就可以用vba搜寻这些自己独特的标记来根据excel内容填充word了. 第 ...
- POI向Excel中写入数据及追加数据
import org.apache.poi.xssf.usermodel.XSSFCell; import org.apache.poi.xssf.usermodel.XSSFRow; import ...
- 使用java Apache poi 根据word模板生成word报表
项目开发过程中,客户提出一堆导出报表的需求,需要导出word格式,页眉还需要加上客户公司的logo,试了几种方案,最后选择了用 Apache poi 加上自定义标签的方式实现. 目前功能还比较简单,一 ...
- 读取word模板,填充数据后导出
一.需求说明 定期生成word报告,报告中含有文本.表格.图表等元素,依次获取进行替换,保留原有样式,生成新的word文档 二.引入依赖 <dependency> <groupId& ...
- poi导出word模板项目实例(一个文件)
在页面上填写值,然后导出到word模板中,并把页面上的值带到模板中,也就是导出word文档,提前有word 的模板形式, 1.jsp 页面 <table class="formTa ...
- 复制excel表,往excel表中写入数据
import java.io.FileInputStream;import java.io.FileOutputStream;import java.io.IOException;import jav ...
随机推荐
- NO.2:自学tensorflow之路------BP神经网络编程
引言 在上一篇博客中,介绍了各种Python的第三方库的安装,本周将要使用Tensorflow完成第一个神经网络,BP神经网络的编写.由于之前已经介绍过了BP神经网络的内部结构,本文将直接介绍Tens ...
- 图解 Go 并发
你很可能从某种途径听说过 Go 语言.它越来越受欢迎,并且有充分的理由可以证明. Go 快速.简单,有强大的社区支持.学习这门语言最令人兴奋的一点是它的并发模型. Go 的并发原语使创建多线程并发程序 ...
- 最新Python笔试题2017 涵盖知识面广泛
引言 想找一份Python开发工作吗?那你很可能得证明自己知道如何使用Python.下面这些问题涉及了与Python相关的许多技能,问题的关注点主要是语言本身,不是某个特定的包或模块.每一个问题都可以 ...
- (第九周)Beta-1阶段成员贡献分
项目名:食物链教学工具 组名:奋斗吧兄弟 组长:黄兴 组员:李俞寰.杜桥.栾骄阳.王东涵 个人贡献分=基础分+表现分 基础分=5*5*0.5/5=2.5 成员得分如下: 成员 基础分 表现分 个人贡献 ...
- 结对编程-->总结报告
项目github地址 PSP时间表格 结对编程中关于Information Hiding, Interface Design, Loose Coupling原则的使用 Information Hidi ...
- 第二阶段Sprint冲刺会议5
进展:能够保存到手机或内存卡上,没有实现自己选路径,指定路径为内存卡并能够播放已录制好的视频.
- Teamwork(The second day of the team)
梦之翼 5.20工作汇报: Master:杨灵超 产品负责人:杨家安 第一次Sprint的目标和时间: 目标:这一次的sprint我们想先做成一个可以运行的可以展示,但是功能或许还不是很完善的一个模型 ...
- ADO.NET使用using关闭数据库连接
using (SqlConnection conn = new SqlConnection(source)) { // open the connoction conn.Open(); // Do s ...
- profibus总线和profibus dp的区别
profibus总线和profibus dp的区别:PROFBUS是一种国际性的开放式的现场总线标准,它既可以用于高速并且对于时间苛求的数据传输,也可以用于大范围的复杂通讯场合.PROFBUS-DP是 ...
- 第六周PSP&进度条
团队项目PSP 一.表格: C类型 C内容 S开始时间 E结束时间 I时间间隔 T净时间(mins) 预计花费时间(mins) 讨论 讨论alpha完成情况并总结 9:40 11:20 17 ...