前言:
现在小伙伴们对“java poi word转图片”大约比较重视,同学们都需要剖析一些“java poi word转图片”的相关资讯。那么小编也在网摘上网罗了一些对于“java poi word转图片””的相关文章,希望咱们能喜欢,同学们一起来学习一下吧!利用EasyPoi导出Word模板,含图片。
前几天写过一篇<利用js工具wordexport将页面导出为Word文档>,发现用js工具导出的Word样式有点乱(包括字体大小、行列布局等等)。如果改动样式去适应Word,这样有点稍显麻烦。所以再三思考决定从后端处理导出Word模板。这里我们使用的是EasyPoi,相对比较容易入手。简单的记录一下。
1、关于EasyPoi简单介绍一点点:
主打功能就是easy(容易),方便的写出Excel导出、Excel模板导出、Excel导入、Word模板导出等等。
2、特点:
(1).设计精巧,使用简单。
(2).接口丰富,扩展简单。
(3).默认值多,write less do more。
(4).spring mvc支持,web导出可以简单明了。
3、功能:
Excel自适应xls和xlsx两种格式,word只支持docx模式。
补充:
关于EasyPoi的更多资料请见:
4、 案例分析:
(1)、maven为例,pom添加所需包。
1.easypoi-annotation
基础注解包,作用与实体对象上,拆分后方便maven多工程的依赖管理。
2. easypoi-base
导入导出的工具包,可以完成Excel导出导入、Word导出、Excel的导出功能。
3. easypoi-web
耦合了spring-mvc基于AbstractView,极大的简化spring-mvc下的导出功能。
(2) 、前端界面
这是我们将要导出为Word的一个简单的table
(3) 对应前端界面table的Word模板
补充:模板指令
三目运算:{{test ? obj:obj2}}。
le: 代表长度{{le:()}}。
fd: 格式化时间 {{fd:(obj;yyyy-MM-dd)}}。
fe: 遍历数据,创建row。
!fe: 遍历数据不创建row。
$fe: 下移插入,把当前行,下面的行全部下移.size()行,然后插入。
#fe: 横向遍历。
v_fe: 横向遍历值。
!if: 删除当前列 {{!if:(test)}}。
sum: 统计数据
......
整体风格和el表达式类似,Java猿们应该比较熟悉。
采用的写法是{{}}代表表达式,然后根据表达式里面的数据取值。
举例:
{{name}}:将前台table传入的name的值(odysee)插入到Word模板中。
其余同理。
(4) 前台js函数传值
利用数组将前台数据发送给后端。
(5) 后台处理方法
注意看里面的注释,写的比较清楚了。
注意几点:
(1) Word模板的路径(这里我的是在D盘,可以自定义路径)。
(2) 将table导出为Word的路径(导出为odyseeWord.docx,可以自定义路径)。
(3) 对图片的处理
(6) 导出Word
点击导出Word按钮,提示成功导出。
在我们的D盘下已经生成了我们的Word文件
打开查看是否跟我们的table内容一致
没什么问题
(7)补充大家可能会遇到的问题
1、设置图片路径问题
image.setUrl(url);
错误信息---------------------------
URL===>D:\apache-tomcat-8.5.38\webapps\odysee\http:\localhost:80\hrFiles\075\6499E8D747434F978C00AD5EEFDE2C5A.jpg (文件名、目录名或卷标语法不正确。)
错误信息---------------------------
解释:
D:\apache-tomcat-8.5.38\webapps\odysee\:
image.setUrl(url);默认的路径在此项目下。
http:\localhost:80\hrFiles\075\6499E8D747434F978C00AD5EEFDE2C5A.jpg:
传入图片的URL路径。
利用image.setUrl(url)设置图片路径时,它会直接拼接。
解决方案:
1、 传入的图片的URL使用相对路径。
2、 或者使用绝对路径,直接从盘符定位。
3、 使用image.setData(bytesArray);
如下图:
WordImageEntity实体类有两种构造方式,个人推荐使用传入byte
方法中
总结:
这里咱们使用easypoi工具不是很完美,作者也给出了一些提示,如下图。
如果大家还有其他方式来实现欢迎留言交流,共同进步。
感谢支持。
标签: #java poi word转图片