java导出word文档
2018-02-08 14:43
495 查看
1.应用场景,java下载world定制模板,并自动填充参数时使用
1.1 使用技术 SpringMVC
2.先看我的模板截图
红色方框为自己定义的一些参数
3.请求的Action
@SuppressWarnings("deprecation")
@RequestMapping(value = "down-talk-word")
public void down_talk_word(ModelMap model,approvalModel query,HttpServletResponse response, HttpServletRequest request) throws IOException{
response.reset();
String logoRealPathDir = request.getSession().getServletContext().getRealPath("//modile//TSC-talk-record.docx");//获取文档路径
TempleWordUtil xwpfTUtil=null; //声明工具类
XWPFDocument doc=null; //仅支持2007之后的版本 需要引入poi包 import org.apache.poi.xwpf.usermodel.XWPFDocument;
InputStream is = null;
OutputStream os=null;
try {
//查询员工基本信息
EmployeeModel employeeInfo=employeeService.getEmployeeOrganization(query.getEmployeeCode());
Map<String, Object> params=null;
/*存入替换模板数据*/
params = new HashMap<String, Object>();
params.put("${name}",employeeInfo.getName());
params.put("${sectionName}", employeeInfo.getSectionName());
params.put("${directManager}", employeeInfo.getDirectManager());
params.put("${employeeCode}",employeeInfo.getEmployeeCode());
params.put("${positionCode}", employeeInfo.getPositionCode());
xwpfTUtil = new TempleWordUtil();
is = new FileInputStream(logoRealPathDir);
doc = new XWPFDocument(is);
xwpfTUtil.replaceInTable(doc, params); //下方定义的工具类,用于替换word文档中定义的参数
//替换表格里面的变量
xwpfTUtil.replaceInTable(doc, params);
os = response.getOutputStream();
} catch (Exception e) {
e.printStackTrace();
}finally{
//设置数据类型
response.setContentType("application/vnd.ms-excel");
//设置文件名称
response.setHeader("Content-Disposition",
"attachment; filename="+ "TSC-talk-record"+java.net.URLEncoder.encode(DateUtil.getExportDate()+ ".docx", "UTF-8"));
doc.write(os);
xwpfTUtil.close(os);
xwpfTUtil.close(is);
os.flush();
os.close();
}
}4.工具类
package common.util;
import java.io.IOException;
import java.io.InputStream;
import java.io.OutputStream;
import java.util.Iterator;
import java.util.List;
import java.util.Map;
import java.util.regex.Matcher;
import java.util.regex.Pattern;
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;
public class TempleWordUtil {
/**
* 替换段落里面的变量
*
* @param doc 要替换的文档
* @param params 参数
*/
public 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 参数
*/
public void replaceInPara(XWPFParagraph para, Map<String, Object> params) {
List<XWPFRun> runs;
Matcher matcher;
if (this.matcher(para.getParagraphText()).find()) {
runs = para.getRuns();
int start = -1;
int end = -1;
String str = "";
for (int i = 0; i < runs.size(); i++) {
XWPFRun run = runs.get(i);
String runText = run.toString();
if ('$' == runText.charAt(0)&&'{' == runText.charAt(1)) {
start = i;
}
if ((start != -1)) {
str += runText;
}
if ('}' == runText.charAt(runText.length() - 1)) {
if (start != -1) {
end = i;
break;
}
}
}
for (int i = start; i <= end; i++) {
para.removeRun(i);
i--;
end--;
}
for (String key : params.keySet()) {
if (str.equals(key)) {
para.createRun().setText((String) params.get(key));
break;
}
}
}
}
/**
* 替换表格里面的变量
*
* @param doc 要替换的文档
* @param params 参数
*/
public 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) {
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
*/
public void close(InputStream is) {
if (is != null) {
try {
is.close();
} catch (IOException e) {
e.printStackTrace();
}
}
}
/**
* 关闭输出流
*
* @param os
*/
public void close(OutputStream os) {
if (os != null) {
try {
os.close();
} catch (IOException e) {
e.printStackTrace();
}
}
}
}
4. 前台页面定义下载按钮,交互下应该就可以了
1.1 使用技术 SpringMVC
2.先看我的模板截图
红色方框为自己定义的一些参数
3.请求的Action
@SuppressWarnings("deprecation")
@RequestMapping(value = "down-talk-word")
public void down_talk_word(ModelMap model,approvalModel query,HttpServletResponse response, HttpServletRequest request) throws IOException{
response.reset();
String logoRealPathDir = request.getSession().getServletContext().getRealPath("//modile//TSC-talk-record.docx");//获取文档路径
TempleWordUtil xwpfTUtil=null; //声明工具类
XWPFDocument doc=null; //仅支持2007之后的版本 需要引入poi包 import org.apache.poi.xwpf.usermodel.XWPFDocument;
InputStream is = null;
OutputStream os=null;
try {
//查询员工基本信息
EmployeeModel employeeInfo=employeeService.getEmployeeOrganization(query.getEmployeeCode());
Map<String, Object> params=null;
/*存入替换模板数据*/
params = new HashMap<String, Object>();
params.put("${name}",employeeInfo.getName());
params.put("${sectionName}", employeeInfo.getSectionName());
params.put("${directManager}", employeeInfo.getDirectManager());
params.put("${employeeCode}",employeeInfo.getEmployeeCode());
params.put("${positionCode}", employeeInfo.getPositionCode());
xwpfTUtil = new TempleWordUtil();
is = new FileInputStream(logoRealPathDir);
doc = new XWPFDocument(is);
xwpfTUtil.replaceInTable(doc, params); //下方定义的工具类,用于替换word文档中定义的参数
//替换表格里面的变量
xwpfTUtil.replaceInTable(doc, params);
os = response.getOutputStream();
} catch (Exception e) {
e.printStackTrace();
}finally{
//设置数据类型
response.setContentType("application/vnd.ms-excel");
//设置文件名称
response.setHeader("Content-Disposition",
"attachment; filename="+ "TSC-talk-record"+java.net.URLEncoder.encode(DateUtil.getExportDate()+ ".docx", "UTF-8"));
doc.write(os);
xwpfTUtil.close(os);
xwpfTUtil.close(is);
os.flush();
os.close();
}
}4.工具类
package common.util;
import java.io.IOException;
import java.io.InputStream;
import java.io.OutputStream;
import java.util.Iterator;
import java.util.List;
import java.util.Map;
import java.util.regex.Matcher;
import java.util.regex.Pattern;
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;
public class TempleWordUtil {
/**
* 替换段落里面的变量
*
* @param doc 要替换的文档
* @param params 参数
*/
public 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 参数
*/
public void replaceInPara(XWPFParagraph para, Map<String, Object> params) {
List<XWPFRun> runs;
Matcher matcher;
if (this.matcher(para.getParagraphText()).find()) {
runs = para.getRuns();
int start = -1;
int end = -1;
String str = "";
for (int i = 0; i < runs.size(); i++) {
XWPFRun run = runs.get(i);
String runText = run.toString();
if ('$' == runText.charAt(0)&&'{' == runText.charAt(1)) {
start = i;
}
if ((start != -1)) {
str += runText;
}
if ('}' == runText.charAt(runText.length() - 1)) {
if (start != -1) {
end = i;
break;
}
}
}
for (int i = start; i <= end; i++) {
para.removeRun(i);
i--;
end--;
}
for (String key : params.keySet()) {
if (str.equals(key)) {
para.createRun().setText((String) params.get(key));
break;
}
}
}
}
/**
* 替换表格里面的变量
*
* @param doc 要替换的文档
* @param params 参数
*/
public 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) {
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
*/
public void close(InputStream is) {
if (is != null) {
try {
is.close();
} catch (IOException e) {
e.printStackTrace();
}
}
}
/**
* 关闭输出流
*
* @param os
*/
public void close(OutputStream os) {
if (os != null) {
try {
os.close();
} catch (IOException e) {
e.printStackTrace();
}
}
}
}
4. 前台页面定义下载按钮,交互下应该就可以了
相关文章推荐
- 【Java】导出word文档之freemarker导出
- java使用freemarker模板导出word(带有合并单元格)文档
- JAVA不使用POI,用PageOffice动态导出Word文档
- Java导出Word文档案例
- Java利用freemaker和(excelXML表格或wordXML表格),导出自己任何想要格式的文档
- java 将ftl文件作为模板导出word文档
- java 导出word格式的文档
- Java导出word/execl文档
- Java导出Word文档
- java导出word文档
- java freemaker 导出word文档 高逼格教程
- JAVA 数据导出Word文档模板的功能实现
- java导出word文档
- Java导出Word文档(可设置字体)
- Java 用Freemarker完美导出word文档(带图片)
- Java导出Word文档使用iText操作
- java开发导出Excel和Word文档
- JAVA原始的导出excel文件,快捷通用 方便 还能够导出word文档哦
- JAVA利用FreeMarker生成(导出)Word文档(Bug修改)
- java页面导出excel实例,java页面导出word文档实例