springboot 集成poi导出word(一)
使用ruoyi-前后端分离版本,根据word模板导出,包含表格和图片。
一、创建模板

列表使用{{}},文本使用[]
二、引入依赖
<!-- excel工具 -->
<dependency>
<groupId>org.apache.poi</groupId>
<artifactId>poi-ooxml</artifactId>
</dependency> <!-- Word工具 -->
<dependency>
<groupId>com.deepoove</groupId>
<artifactId>poi-tl</artifactId>
<version>1.10.0</version>
</dependency>
三、调用接口
@PostMapping("/exportPic")
public void exportPic(HttpServletResponse response, InfoGroup infoGroup)
{
//从数据库中获取数据,组成list
groupService.exportPic(response,list);
}
四、WordUtil导出类
package com.ruoyi.common.utils.poi; import com.deepoove.poi.XWPFTemplate;
import com.deepoove.poi.config.Configure;
import com.deepoove.poi.data.PictureRenderData;
import com.deepoove.poi.plugin.table.LoopRowTableRenderPolicy;
import com.deepoove.poi.policy.PictureRenderPolicy;
import java.awt.image.BufferedImage;
import java.io.*;
import java.util.*;
import java.util.List; import com.ruoyi.common.core.domain.AjaxResult;
import org.apache.poi.util.Units;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory; import javax.imageio.ImageIO;
import javax.servlet.http.HttpServletResponse; import static com.deepoove.poi.data.PictureType.PNG;
import static com.ruoyi.common.config.RuoYiConfig.getProfile; /**
* Word导出方法
*/
public class WordUtil {
private static final Logger log = LoggerFactory.getLogger(WordUtil.class);
/**
* 导出信息图片
* @param data 导出模板数据
* @param response
* @return
* @throws Exception
*/
public AjaxResult exportPic(HttpServletResponse response,List<Map<String, Object>> data) throws Exception {
response.setContentType("application/vnd.openxmlformats-officedocument.spreadsheetml.sheet");
response.setCharacterEncoding("utf-8"); Map<String, Object> datas = new HashMap<>();//传入word数据
List<Map<String, Object>> list = new ArrayList<Map<String, Object>>();
List<String> pictureTag = new ArrayList<>();//图片处理
for (int i = 0; i < data.size(); i++) {
Map<String, Object> detailMap = new HashMap<String, Object>();//将word中标签名的例和对应数据保存到map
detailMap.put("name", data.get(i).get("name"));
//添加图片
BufferedImage image = ImageIO.read(new File(picPath));
detailMap.put("photo", new PictureRenderData(100, 100, PNG, image));
pictureTag.add("photo");//用于设置图片
}
list.add(detailMap);//将设置好的行保存到list集合中
}
//图片配置
LoopRowTableRenderPolicy policy = new LoopRowTableRenderPolicy();
Configure config = Configure.builder().bind("lists", policy).build();//设置列表配置,如果有多个列表时需加.bind("list1", policy) 新列表配置即可
for (String tag : pictureTag
) {
config.customPolicy(tag, new PictureRenderPolicy());//设置图片,不然保存的是一串字符
}
datas.put("lists", list); //将列表保存到渲染的map中
//3.创建XWPFTemplate对象,并设置读取模板路径和要渲染的数据
String inputFile = getProfile() + "\\template\\pic.docx";
XWPFTemplate template = XWPFTemplate.compile(inputFile, config).render(datas);
//compile(模板路径,对应的配置)方法是设置模板路径和模板配置的,如果不设置配置时可不传config
//render(datas)方法是用来渲染数据,将准备好的map数据方进去渲染
//4.模板的输出,用FileOutputStream输出流(可以输出到指定文件位置,也可以用ajax直接返回给浏览器下载)
//FileOutputStream out = null;//创建文件输出流并指定位置
try {
//out = new FileOutputStream(getProfile() + "\\download\\picOut.docx");
//template.write(out);
//out.flush();
//out.close();
template.write(response.getOutputStream());
template.close();
return AjaxResult.success("成功");
} catch (FileNotFoundException e) {
e.printStackTrace();
return AjaxResult.error(e.getMessage());
} catch (IOException e) {
e.printStackTrace();
return AjaxResult.error(e.getMessage());
}
}
}
五、导出页面调用,使用现成的导出方法
this.download('test/exportPic', {
...this.queryParams
}, `test.docx`)
springboot 集成poi导出word(一)的更多相关文章
- SpringBoot 集成 FreeMarker 导出 Word 模板文件(底部附源码)
思路解说 word 模板文件(doc 或 docx 文件)另存为 xml 文件 将后缀 xml 改成 html:大部分文档会改成 ftl(FreeMarker 的后缀名),因为 word 文件另存为 ...
- SpringBoot集成文件 - 如何使用POI导出Word文档?
前文我们介绍了通过Apache POI导出excel,而Apache POI包含是操作Office Open XML(OOXML)标准和微软的OLE 2复合文档格式(OLE2)的Java API.所以 ...
- poi导出word
最近做了个poi导出word的功能 下面是代码: 一个可以参考的例子: package com.lzb.crm.web; import java.io.FileOutputStream; import ...
- java工具类POI导出word
1.新建一个word,里面填写内容,如: 2.导出wordjava类 /** * POI导出word测试 * @throws Exception */ @RequestMapping(value=&q ...
- poi导出word表格详解 超详细了
转:非常感谢原作者 poi导出word表格详解 2018年07月20日 10:41:33 Z丶royAl 阅读数:36138 一.效果如下 二.js代码 function export_word( ...
- poi导出word时设置兼容性
接上一篇poi导出word http://www.cnblogs.com/xiufengd/p/4708680.html. public static void setAuto(XWPFDocumen ...
- 使用POI导出Word(含表格)的实现方式及操作Word的工具类
.personSunflowerP { background: rgba(51, 153, 0, 0.66); border-bottom: 1px solid rgba(0, 102, 0, 1); ...
- Spring MVC中使用POI导出Word
内容绝大部分来源于网络 准备工作 准备[XwpfTUtil]工具类(来源于网络) 准备word模版 下载[XwpfTUtil]工具类 import org.apache.poi.xwpf.usermo ...
- POI导出Word插入复选框
POI功能比较强大,但是有些不常用功能比如插入特殊符号,不知道API怎么调用 Word里要插入复选框,首先想到的是POI有没有提供现成的API,搜了一番,貌似都说不直接支持 http://stacko ...
- poi导出word模板项目实例(一个文件)
在页面上填写值,然后导出到word模板中,并把页面上的值带到模板中,也就是导出word文档,提前有word 的模板形式, 1.jsp 页面 <table class="formTa ...
随机推荐
- Postgresql表膨胀率计算
一.简介 PostgreSQL自带了pgstattuple模块,可用于精确计算表的膨胀率.譬如这里的tuple_percent字段就是元组实际字节占关系总大小的百分比,用1减去该值即为膨胀率. 二.示 ...
- ABP微服务系列学习-搭建自己的微服务结构(四)
上篇我们实现了认证服务和网关服务,基本我们的基础服务已经完成了,接下来我们才需要做服务的数据迁移.这里我们需要使用EF的CodeFirst模式.通过DotnetCli的命令去操作: dotnet ef ...
- 排查问题-输出pojo日志,尽量用json
背景: 下午在做一个前后端md5加密签名校验. 前端用参数A,B,C,经过MD5加密函数,得到签名D. 然后前端带着ABCD一块来到后端. 同样的,后端拿到请求后,用MD5函数对ABC进行加密,得到签 ...
- 解决用flex布局时内容溢出的问题
1,2正常现象如下: 2,点击折叠图标 再点折叠 无图标了 解决:flex:1,width:0 就可以了
- WPF项目需要不断更新前台图片时,碰到“System.IO.IOException: 文件“xxx”正由另一进程使用“问题的解决
问题描述 项目中要求能不断拍照并更新显示图片,使用FileStream在本地创建了图片文件: 当下次重新拍照前删除之前拍过的图片时,提示"System.IO.IOException: 文件& ...
- Day 23 23.1:js加密算法
js加密算法 逆向重点掌握的内容: 1.逆向的思维 2.网站逆向的分析思路和步骤 注意:重点不是放在代码中,而是分析的思路和套路(技巧) 逆向到底是什么? 通俗来讲,逆向就是处理爬虫过程中对于加密数据 ...
- vscode格式化
1.tslint TypeScript的格式化 2.esLint 3.prettier 4.vetur 格式化html,css,vue
- @Target:注解的作用目标
@Target:注解的作用目标 @Target(ElementType.TYPE)--接口.类.枚举.注解 @Target(ElementType.FIELD)--字段.枚举的常量 @Target(E ...
- 阿里巴巴Java代码规范(一)
现代软件架构都需要协同开发完成,高效协作即降低协同成本,提升沟通效率,所谓无规矩不成方圆,无规范不能协作. 本博客是对<阿里巴巴Java开发手册>的学习记录.大多记录的是强制规约,具体请参 ...
- node版本和用的包不兼容问题,头疼
经常遇到node版本和包不兼容的问题,在茫茫大海中学习的时候发现一个nvm,可以随时切换node版本,简直不要太开心,附上流程 环境windows 首先:下载一个nvm包https://github. ...