乔山办公网我们一直在努力
您的位置:乔山办公网 > word文档 > word图片导出-实测,利用EasyPoi导出含图片的Word,附带案例

word图片导出-实测,利用EasyPoi导出含图片的Word,附带案例

作者:乔山办公网日期:

返回目录: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的更多资料请见:http://easypoi.mydoc.io/


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.38webappsodyseehttp:localhost:80hrFiles0756499E8D747434F978C00AD5EEFDE2C5A.jpg (文件名、目录名或卷标语法不正确。)


错误信息---------------------------


解释:


D:apache-tomcat-8.5.38webappsodysee:


image.setUrl(url);默认的路径在此项目下。


http:localhost:80hrFiles0756499E8D747434F978C00AD5EEFDE2C5A.jpg:


传入图片的URL路径。


利用image.setUrl(url)设置图片路径时,它会直接拼接。


解决方案:


1、 传入的图片的URL使用相对路径。


2、 或者使用绝对路径,直接从盘符定位。


3、 使用image.setData(bytesArray);


如下图:


WordImageEntity实体类有两种构造方式,个人推荐使用传入byte


方法中


总结:


这里咱们使用easypoi工具不是很完美,作者也给出了一些提示,如下图。


如果大家还有其他方式来实现欢迎留言交流,共同进步。


感谢支持。


相关阅读

  • excel密码-给Excel2013设置打开密码

  • 乔山办公网excel表格制作
  • 前面我们了解了给Excel2013中特定区域单元格加密的方法,现在,小编要给大家分享的是,如何在Excel2013中设置打开密码,完成之后需要密码才能打开这个工作表哦。-excel密码
关键词不能为空
极力推荐

ppt怎么做_excel表格制作_office365_word文档_365办公网