poi导出word模板项目实例(一个文件)
在页面上填写值,然后导出到word模板中,并把页面上的值带到模板中,也就是导出word文档,提前有word 的模板形式,
1.jsp 页面
<table class="formTable">
<TR>
<TD class="label">会议地点</TD>
<TD class="content">
<INPUT id="meetingSite" type="text" class="text" name="CommonLink/meetingSite"></TD>
<TD class="label">会议人员</TD>
<TD>
<INPUT id="meetingPerson" type="text" class="text" name="CommonLink/meetingPerson"></TD>
</TR>
<TR>
<TD class="label">会议内容</TD>
<TD class="content">
<INPUT id="meetingContent" type="text" class="text" name="CommonLink/meetingContent"></TD>
<TD class="label">会议时间</TD>
<TD><INPUT id="meetingDate" type="text" class="text" name="CommonLink/meetingDate"></TD>
</TR>
<TR>
<TD class="label">总经理</TD>
<TD class="content">
<INPUT id="manager" type="text" class="text" name="CommonLink/manager"></TD>
<TD class="label">采购部门</TD>
<TD><INPUT id="purchaseDep" type="text" class="text" name="CommonLink/purchaseDep"></TD>
</TR>
</table>
<div id="btns" class="form-btns">
<INPUT value="导出word文档" type="button" class="btn" onclick="exportWord();">
</div>
2.js异步的方法
function exportWord(){
var data = setData();
jQuery.post("http://localhost:8080/expWord/GKBX29_word.jsp",data,function(data1){
var url = data1; //回调函数,返回值是地址,data1
window.open(url); //打开
});
}
function setData(){
var data = {};
data.author='zzz';
data.meetingSite = document.getElementById("meetingSite").value;
data.purchaseDep = document.getElementById("purchaseDep").value;
data.meetingPerson = document.getElementById("meetingPerson").value;
data.meetingContent = document.getElementById("meetingContent").value;
data.meetingDate = document.getElementById("meetingDate").value;
data.manager = document.getElementById("manager").value;
return data;
}
3.GKBX29_word.jsp其实是后台的处理方法,因为本次开发用EOS,所以在jsp用request接收值,并传递到模板
<%@page import="java.util.HashMap"%>
<%@page import="java.util.Map"%>
<%@page import="com.boco.eoms.word.client.word"%> <%
request.setCharacterEncoding("UTF-8"); String author = request.getParameter("author"); String meetingSite = request.getParameter("meetingSite");
String purchaseDep = request.getParameter("purchaseDep");
String meetingPerson = request.getParameter("meetingPerson");
String meetingContent = request.getParameter("meetingContent");
String meetingDate = request.getParameter("meetingDate");
String manager = request.getParameter("manager"); word w = new word();
Map map = new HashMap(); map.put("author", author); map.put("meetingSite", meetingSite);
map.put("purchaseDep", purchaseDep);
map.put("meetingPerson", meetingPerson);
map.put("meetingContent", meetingContent);
map.put("meetingDate", meetingDate);
map.put("manager", manager); String url = w.replacWordByMap(map, "model"); //模板名称,默认是.doc文件
response.getWriter().write(url);
%>
4. 生成word 的方法
package com.boco.eoms; import java.io.ByteArrayInputStream;
import java.io.ByteArrayOutputStream;
import java.io.File;
import java.io.FileInputStream;
import java.io.FileOutputStream;
import java.io.IOException;
import java.io.OutputStream;
import java.text.SimpleDateFormat;
import java.util.Date;
import java.util.HashMap;
import java.util.Map; import org.apache.poi.hwpf.HWPFDocument;
import org.apache.poi.hwpf.usermodel.Range;
import org.apache.poi.poifs.filesystem.DirectoryEntry;
import org.apache.poi.poifs.filesystem.POIFSFileSystem; //***************************************************************// //** 需要使用变量的地方可以用如下替换 ${name} ,name为变量名,在map中key使用变量名,value使用要替换成的字符串,如 map.put("name","栾主峰") **//
//***************************************************************// public class word { /**
* 根据传入的模板编号将变量替换成实际值之后生成word文档
* 需要使用变量的地方word中可以用变量替换 ,格式: ${变量名} 如: ${name}
* name为变量名,在map中key使用变量名,value使用要替换成的字符串
* 如 map.put("name","栾主峰")
* @param maps 变量集合
* @param DocName 模板名称
* @return 重新生成的文档名称包含全路径,返回-1时,文件生成错误
*/
public String createWordByMap(Map<String, String> maps, String DocName) {
String path = this.getClass().getClassLoader().getResource("/")
.getPath()
+ "attach/";//获取基础路径
String docModelPath = path + "word/model/"; //生成模板所在路径
String docPath = path + "word/create/" + getCurrentDateTime("yyyyMMdd")
+ "/";
//+"/"+getCurrentDateTime("yyyyMMddHHmmssSSS");
java.io.File filetemp = new java.io.File(docPath);
if (!filetemp.exists())
filetemp.mkdirs();
String destFile = docPath + getCurrentDateTime("yyyyMMddHHmmssSSS")
+ ".doc";
HWPFDocument document = new word().replaceDoc(docModelPath + DocName
+ ".doc", maps);
if (document != null)
{
ByteArrayOutputStream ostream = new ByteArrayOutputStream();
try {
document.write(ostream);
// 输出word文件
OutputStream outs = new FileOutputStream(destFile);
outs.write(ostream.toByteArray());
outs.close(); } catch (IOException e) {
e.printStackTrace();
destFile = "-1";
}
} else
destFile = "-1";
return destFile;
} /**
*
* @param destFile
* @param fileCon
*/
public void exportDoc(String destFile, String fileCon) {
try {
//doc content
ByteArrayInputStream bais = new ByteArrayInputStream(fileCon
.getBytes());
POIFSFileSystem fs = new POIFSFileSystem();
DirectoryEntry directory = fs.getRoot();
directory.createDocument("WordDocument", bais);
FileOutputStream ostream = new FileOutputStream(destFile);
fs.writeFilesystem(ostream);
bais.close();
ostream.close(); } catch (IOException e) {
e.printStackTrace();
}
} /**
* 读取word模板并替换变量
* @param srcPath
* @param map
* @return
*/
public HWPFDocument replaceDoc(String srcPath, Map<String, String> map) {
try {
// 读取word模板
FileInputStream fis = new FileInputStream(new File(srcPath));
HWPFDocument doc = new HWPFDocument(fis);
// 读取word文本内容
Range bodyRange = doc.getRange();
// 替换文本内容
for (Map.Entry<String, String> entry : map.entrySet()) {
bodyRange.replaceText("${" + entry.getKey() + "}", entry
.getValue());
}
return doc;
} catch (Exception e) {
e.printStackTrace();
return null;
}
} //得到当前的系统时间
/*
根据输入的格式(String _dtFormat)得到当前时间格式
*/
public String getCurrentDateTime(String _dtFormat) {
String currentdatetime = "";
try {
Date date = new Date(System.currentTimeMillis());
SimpleDateFormat dtFormat = new SimpleDateFormat(_dtFormat);
currentdatetime = dtFormat.format(date);
} catch (Exception e) {
System.out.println("时间格式不正确");
e.printStackTrace();
}
return currentdatetime;
} }
5.模板中的样式
poi导出word模板项目实例(一个文件)的更多相关文章
- java工具类POI导出word
1.新建一个word,里面填写内容,如: 2.导出wordjava类 /** * POI导出word测试 * @throws Exception */ @RequestMapping(value=&q ...
- 使用java Apache poi 根据word模板生成word报表
项目开发过程中,客户提出一堆导出报表的需求,需要导出word格式,页眉还需要加上客户公司的logo,试了几种方案,最后选择了用 Apache poi 加上自定义标签的方式实现. 目前功能还比较简单,一 ...
- 使用POI导出Word(含表格)的实现方式及操作Word的工具类
.personSunflowerP { background: rgba(51, 153, 0, 0.66); border-bottom: 1px solid rgba(0, 102, 0, 1); ...
- poi导出word
最近做了个poi导出word的功能 下面是代码: 一个可以参考的例子: package com.lzb.crm.web; import java.io.FileOutputStream; import ...
- POI往word模板中写入数据
转: POI往word模板中写入数据 2018年03月24日 16:00:22 乄阿斗同學 阅读数:2977 版权声明:本文为博主原创文章,未经博主允许不得转载. https://blog.csdn ...
- poi导出word表格详解 超详细了
转:非常感谢原作者 poi导出word表格详解 2018年07月20日 10:41:33 Z丶royAl 阅读数:36138 一.效果如下 二.js代码 function export_word( ...
- 使用word模板生成pdf文件
使用word模板生成pdf文件 源码:UserWord
- poi导出word时设置兼容性
接上一篇poi导出word http://www.cnblogs.com/xiufengd/p/4708680.html. public static void setAuto(XWPFDocumen ...
- SpringBoot 集成 FreeMarker 导出 Word 模板文件(底部附源码)
思路解说 word 模板文件(doc 或 docx 文件)另存为 xml 文件 将后缀 xml 改成 html:大部分文档会改成 ftl(FreeMarker 的后缀名),因为 word 文件另存为 ...
随机推荐
- Git之忽略提交 .gitignore
1.touch .gitignore 创建忽略文件,若此文件已存在,请忽略这一步 2.vi .gitignore 编辑忽略文件,将需要忽略的文件添加到忽略文件中 3.git status 发现忽 ...
- Spark 学习(三) maven 编译spark 源码
spark 源码编译 scala 版本2.11.4 os:ubuntu 14.04 64位 memery 3G spark :1.1.0 下载源码后解压 1 准备环境,安装jdk和scala,具体参考 ...
- 使用命令动态更新JAR包中的文件
动态更新JAR包中的文件,经本人实际测试可正常执行! 一.查询jar包中要替换的文件位置 jar -tvf gateway.jar | grep topjui.config.js 二.在当前 ...
- (转)关于MongoDB你需要知道的几件事
本文列举了颇让作者困惑的一些MongoDB限制,如果你也打算使用MongoDB,那么至少要提前了解这些限制,以免遇到的时候措手不及. 消耗磁盘空间 这是我的第一个困惑:MongoDB会消耗太多的磁盘空 ...
- 《Python网络爬虫相关基础概念》
爬虫介绍 引入 之前在授课过程中,好多同学都问过我这样的一个问题:为什么要学习爬虫,学习爬虫能够为我们以后的发展带来那些好处?其实学习爬虫的原因和为我们以后发展带来的好处都是显而易见的,无论是从实际的 ...
- 119 Pascal's Triangle II 帕斯卡三角形 II Pascal's Triangle II
给定一个索引 k,返回帕斯卡三角形(杨辉三角)的第 k 行.例如,给定 k = 3,则返回 [1, 3, 3, 1].注:你可以优化你的算法到 O(k) 的空间复杂度吗?详见:https://leet ...
- 097 Interleaving String 交错字符串
给定三个字符串 s1, s2, s3, 验证 s3 是否是由 s1 和 s2 交错组成的.例如,给定:s1 = "aabcc",s2 = "dbbca",当 s ...
- Django blog项目知识点总结
数据库操作部分 当我们在Django项目中的models.py下写好创建表的代码后.为了创建好这些数据库表,我们再一次请出我的工程管理助手 manage.py.激活虚拟环境,切换到 manage.py ...
- Spring Boot运行原理
概述 本文主要写了下Spring Boot运行原理,还有一个小例子. Spring4.x提供了基于条件来配置Bean的能力,而Spring Boot的实现也是基于这一原理的. Spring Boot关 ...
- 2566. [51nod 1129] 字符串最大值
[题目描述] 一个字符串的前缀是指包含该字符第一个字母的连续子串,例如:abcd的所有前缀为a, ab, abc, abcd. 给出一个字符串S,求其所有前缀中,字符长度与出现次数的乘积的最大值. 例 ...