easypoi模板导出word并且合并行

导出流程

引入依赖

xml 复制代码
<dependency>
    <groupId>cn.afterturn</groupId>
    <artifactId>easypoi-base</artifactId>
    <version>4.1.2</version>
</dependency>

制作模板

合并行是备注那一列,这一列因为各种列合并的关系,所以每一行所对应的所在列位置都不一样,这是个复杂的模板,如果列都在一个位置,那就更好操作,不用去判断了,下方的遍历判断就是为了找到列所在位置。

因为要导出多页所以用word。
模板提取码:cfmw

合并导出

关键代码:

单页导出:outputUrl是模板路径,map是导出需要用到的信息。

java 复制代码
 @Cleanup XWPFDocument xwpfDocument = WordExportUtil.exportWord07(outputUrl, map);

多页导出:

将上边单页的map自定义多个,每页的格式一样,内容可以不一样,如果不在乎格式,也可以用单页导出,让它根据内容多少自动扩展页数。

java 复制代码
@Cleanup XWPFDocument xwpfDocument = WordExportUtil.exportWord07(outputUrl, hashMaps);

合并行的关键代码:

java 复制代码
XWPFTableCell cell = row1.getCell(6);
//设置合并开始
 cell.getCTTc().addNewTcPr().addNewVMerge().setVal(STMerge.RESTART);
 //设置单元格居中,段落内容居左或右在模板里设置
 cell.setVerticalAlignment(XWPFTableCell.XWPFVertAlign.CENTER);
 //设置合并后的内容,如果要合并后只展示一行内容或者自定义内容,就设置第一行的内容即可,还要把其他单元格内容清空,如果合并所有单元格内容,就不需要设置了
 cell.setText("必须做到稳固、定量、整理、方便和安全");

图示:

导出:

java 复制代码
//设置表格文件名字
String fileName = title;
fileName = URLEncoder.encode(fileName, "UTF8");
//设置返回数据类型
response.setContentType("application/vnd.ms-excel;charset=utf-8");
response.setHeader("Content-Disposition", "attachment;filename=" + fileName + ".docx");
//将表格输出
@Cleanup OutputStream os = response.getOutputStream();
xwpfDocument.write(os);

完整代码

相关推荐
lqz19934 小时前
根据html导出excel和word
html·word·excel
缺点内向8 小时前
C# 中 Word 文档目录的插入与删除指南
开发语言·c#·word·.net
诸神缄默不语1 天前
如何用Python处理文件:Word导出PDF & 如何用Python从Word中提取数据:以处理简历为例
python·pdf·word
初九之潜龙勿用1 天前
C# 操作Word模拟解析HTML标记输出带格式的文本
开发语言·c#·word·office
裤裤兔2 天前
利用VBA批处理word 文档,使用宏对docx文件内容进行批量替换
c#·word·.net··vba·office·宏操作
gc_22992 天前
学习C#调用FreeSpire.Doc包将Word转换为html
c#·html·word·freespire.doc
gc_22992 天前
学习C#调用Microsoft.Office.Interop.Word将Word转换为html
c#·html·word·interop.word
梵克之泪3 天前
根据表格内容和模板文件批量创建word文件,一次性生成多个word文档和批量生成创建PDF文件
pdf·word
栗子~~4 天前
java-根据word模板灵活生成word文档-demo
java·开发语言·word
B博士4 天前
Word中Endnote引用参考文献时正文引用处字体如何标蓝色呢?
word·endnote·引用显示蓝色