java使用POI批量添加图片到word

  • 前言
  • 生成效果图
  • 第一步 添加依赖
  • 第二步 创建要封装的表单数据
  • 第三步 将数据设置到word
    • 注意:文字换行赋值如下
    • 批量设置多张图、文字及描述
  • 授人以鱼不如授人以渔(参考该API)

前言

我们的需求:可以批量的向word中添加图片和文本。在网上找了很久,找到的都是只能向word添加一张图片的,而且都是使用的freemark,一个是找到的需求不满足,另外一个是我也不想使用freemark,因此,我决定用java结合着poi自己手动写一个。

生成效果图

该报告为代码生成,达到的效果是影像和处理建议都可以动态插入多张图片和文字

第一步 添加依赖

该依赖为对poi封装后的依赖,还需自己添加相关poi依赖

 <dependency><groupId>com.deepoove</groupId><artifactId>poi-tl</artifactId><version>1.6.0</version></dependency>

如果你还没有poi依赖,那么可以使用下面的依赖(如果有请忽略下面这些依赖)

<dependency><groupId>org.apache.poi</groupId><artifactId>poi</artifactId><version>4.0.0</version></dependency><dependency><groupId>org.apache.poi</groupId><artifactId>poi-ooxml</artifactId><version>4.0.0</version></dependency><dependency><groupId>org.apache.poi</groupId><artifactId>poi-excelant</artifactId><version>4.0.0</version></dependency><dependency><groupId>org.apache.poi</groupId><artifactId>poi-ooxml-schemas</artifactId><version>4.0.0</version></dependency><dependency><groupId>org.apache.poi</groupId><artifactId>poi-scratchpad</artifactId><version>4.0.0</version></dependency>

第二步 创建要封装的表单数据

CommonReportVo将这个类换成自己的实体类数据,这个方法主要目的是给表格里面的数据赋值并返回(此步骤根据自身实际情况赋值),这里表格是两列,因此我使用二维数组,如果你的word表格数据是多列,那么你可以使用一个实体类进行封装后返回。注:此部分代码仅做表格数据赋值参考

private String[][] setSatelliteReportTemplate(CommonReportVo commonReportVo) {String[] names = {"测试001","测试002,"测试0003","测试0004","测试0005","测试0006"};String lon = GCSUtils.changeToDFM(Double.parseDouble(commonReportVo.getLon()));String lat = GCSUtils.changeToDFM(Double.parseDouble(commonReportVo.getLat()));String status = commonReportVo.getDisaterSituatuin();String taskNo = commonReportVo.getTaskNo();String taskRecord = commonReportVo.getTaskRecord();//多张图片地址 对应测试0004String analysisResult = commonReportVo.getDataAnalysisResult();String suggestion = commonReportVo.getEmergencySuggestion();String otherMaterial = "详见附件文件";String[] values = {status,taskNo,taskRecord,analysisResult,suggestion,otherMaterial};String[][] arrs = new String[names.length][2];//设置行数据for (int i = 0;i < names.length;i ++){arrs[i][0] = names[i];}//设置列数据for (int i = 0;i < values.length;i ++){arrs[i][1] = values[i];}return arrs;}

第三步 将数据设置到word

在上面我们只赋值了表格数据,现在我们将设置标题、时间等其他字段并赋值。

//参数1:响应体
//参数2:上面的二维数据组,即表格中的数据
//参数3:设置标题、时间等字段的封装类
private File setInfo2CommonWord(HttpServletResponse response, String[][] reports,CommonReportVo commonReportVo)  {//创建一个wordXWPFDocument doc = new XWPFDocument();XWPFParagraph title = doc.createParagraph();XWPFRun xwpfRun = title.createRun();//设置标题  测试0001报告xwpfRun.setText(commonReportVo.getReportName() + "报告");xwpfRun.setFontSize(16);//设置标题加粗xwpfRun.setBold(true);//设置标题居中title.setAlignment(ParagraphAlignment.CENTER);XWPFParagraph content1 = doc.createParagraph();XWPFRun xwpfRun1 = content1.createRun();xwpfRun1.setText("报告单位:测试一下");//设置体字体大小xwpfRun1.setFontSize(12);XWPFParagraph content2 = doc.createParagraph();XWPFRun xwpfRun2 = content2.createRun();xwpfRun2.setText("灾害报告时间:" + DateUtil.formatDate1(commonReportVo.getReportTime()));xwpfRun2.setFontSize(12);String imgResult = commonReportVo.getSatelliteImgResult();try {//注意 这是创建表格 创建的是几行几列  这儿需要根据自己实际的表格行列数自己设置//参数1:表示行  参数2:表示列XWPFTable table = doc.createTable(reports.length, 2);//下面的两个for循环就是设置表格数据  这里仅提供样例的设置思路for (int i = 0;i < reports.length; i ++){ //行//得到列数据对象XWPFTableCell cell = table.getRow(i).getCell(0);cell.setWidth("1500");for (int j = 0; j < reports[0].length; j ++){ //列//设置表格每个单元格的样式XWPFParagraph paragraph = table.getRow(i).getCell(j).getParagraphs().get(0);//对齐方式 左边paragraph.setAlignment(ParagraphAlignment.LEFT);XWPFRun run = paragraph.createRun();//字体9号run.setFontSize(9);//以下setPics方法为给表格设置多张图片和文字 看明白后根据自己的业务进行设置//注意 修改此处,然后替换为自己的多张图片if(i == 3 && j == 1){//给对应的单元格设置多张图片setPics(reports[i][j], table.getRow(i), j,imgResult);}else {//给单元格设置文本String[] runTexts=reports[i][j].split("\r\n");for (String s:runTexts){XWPFRun tempRun=paragraph.createRun();tempRun.setFontSize(9);tempRun.setText(s);tempRun.addBreak();}}}}//设置表格为A4纸张 //注意  参数2:表格列数 需要改为自己的列数TableTools.widthTable(table, MiniTableRenderData.WIDTH_A4_FULL, 2);//以下方式自行选择//直接下载 方式一String fileName =commonReportVo.getReportName() + "测试报告";
//            OutputStream out = response.getOutputStream();
//            response.setHeader("Content-Type", "application/ms-winword");
//            response.addHeader("Content-Disposition", "attachment;filename=\"" + URLEncoder.encode(fileName, "UTF-8") + ".docx\"");
//            response.setContentType("application/octet-stream");
//            response.setCharacterEncoding("UTF-8");
//            doc.write(out);//返回文件的方式下载 方式二File file = new File(filePath+File.separator+fileName + ".docx");FileOutputStream fos = new FileOutputStream(file);doc.write(fos);doc.close();return file;} catch (IOException | InvalidFormatException e) {e.printStackTrace();}return null;}

注意:文字换行赋值如下

文字描述如果需要换行时要在设置赋值时的文本中添加\r\n,如:imgResult这个字段中的值是这样的,
imgResult:这是一段测试文字\r\n这是一段测试文字\r\n这是一段测试文字
那么取值后给对应的单元格赋值时这样的

 String[] runTexts=imgResult.split("\r\n");for (String s:runTexts){run=p1.createRun();run.setFontSize(9);run.setText(s);run.addBreak();}

批量设置多张图、文字及描述

//参数1:对应样例中测试0004的多张图片的路径
//参数2:行对象
//参数3:图片上方的文字描述 private void setPics(String analysisResult, XWPFTableRow row, int j,String imgResult) throws InvalidFormatException, IOException {XWPFParagraph p1 = row.getCell(j).getParagraphs().get(0);//通过分隔符获取多张图片路径String[] filePaths = analysisResult.split(",");if(filePaths.length > 0){XWPFRun run = null;//设置图片上的文字描述String[] runTexts=imgResult.split("\r\n");for (String s:runTexts){run=p1.createRun();run.setFontSize(9);run.setText(s);run.addBreak();}//run.addBreak(); //换行//一个单元格中每行设置几张图片 我这里设置的是每行2张图片 然后换行 /注意: 每行几张图片根据自己业务修改for (int k = 0;k < filePaths.length; k +=2){
if(filePaths[k].toUpperCase().contains(".JPG")||filePaths[k].toUpperCase().contains(".PNG")||filePaths[k].toUpperCase().contains(".SVG")){run.addTab();   //添加一个tabint index = filePaths[k].lastIndexOf("\\");String newStr = filePaths[k].substring(index+1);int indexOf = newStr.lastIndexOf(".");String pic = newStr.substring(indexOf);int i = newStr.indexOf("_");//获取文件名String name = newStr.substring(0,i) + pic;//获取文件流InputStream stream = new FileInputStream(filePaths[k]);//设置第一张图片//参数1:图片流数据 参数2:图片类型  参数3 图片名称  参数4:图片宽度  参数5:图片高度run.addPicture(stream, XWPFDocument.PICTURE_TYPE_PNG, "Generated"+k, Units.toEMU(128), Units.toEMU(128));run.addTab();run.addTab();int lastK = k + 1;String name2 = "";if( (lastK) <= filePaths.length-1){int index1 = filePaths[lastK].lastIndexOf("\\");String newStr2 = filePaths[lastK].substring(index1+1);int index2 = newStr2.lastIndexOf(".");String pic2 = newStr2.substring(index2);int i2 = newStr2.indexOf("_");name2 = newStr2.substring(0,i2) + pic2;InputStream stream2 = new FileInputStream(filePaths[lastK]);// 设置第二张图片run.addPicture(stream2, XWPFDocument.PICTURE_TYPE_PNG, "Generated"+lastK, Units.toEMU(128), Units.toEMU(128));//换行run.addBreak();}if(k == filePaths.length-1 && filePaths.length % 2 == 1){run.addBreak();}//设置第一张图片的名称run.setText(name);//这里添加了两个tab 具体添加几个 根据自己的实际格式来调run.addTab();run.addTab();//设置第二张图片的名称run.setText(name2);if(lastK == filePaths.length-1){break;}}}}row.getCell(j).setParagraph(p1);}

自此,整个word批量插入多张图片完成。

授人以鱼不如授人以渔(参考该API)

如果你想使用我这种方式 请结合着以下API
Apache POI Word(docx)

java基于POI批量插入图片到word相关推荐

  1. 使用宏批量插入图片到Word表格

    使用宏批量插入图片到Word表格 创建宏,word 视图->宏>查看宏>输入名称>创建 宏代码如下: Sub imgTbl()If ActiveDocument.Tables. ...

  2. JAVA 通过POI实现插入图片

    JAVA 通过POI实现插入图片 (包含二维码生成) private void exportExcel2(HttpServletRequest request, FileInputStream in) ...

  3. python-docx对Word文档的指定位置(批量)插入图片

    python-docx对Word文档的指定位置(批量)插入图片 任务 实现自动化办公,对请假条.docx文件实现自动插入请假人签名图片. 技术方案 1.python-docx python-docx是 ...

  4. word文档批量插入图片及其文件名

    word文档批量插入图片及其文件名-宏脚本处理 Sub PicWithCaption()Dim xFileDialog As FileDialogDim xPath, xFile As Variant ...

  5. Java基于POI对PPT的基本操作

    Java基于POI对PPT的基本操作 在Java中对PPT文件进行操作的话,我使用的是Apache的开源项目POI.该项目的功能主要是使用Java开发或生成微软办公文件,比如:Word.Excel.P ...

  6. 【python批量插入图片到一个pdf中】

    批量插入图片到一个pdf中 需求 解决思路 代码详解 需求 把大量的img图片插入到一个pdf中,一张图片为pdf的一页 解决思路 先把大量的图片转为一个个的pdf,然后合并所有的pdf 话不多说,直 ...

  7. PPT精灵:批量插入图片生成幻灯片

    PPT精灵:批量插入图片生成幻灯片 批量插入图片生成幻灯片,每一张图片生成一页PPT,自动插入图片名称,以及日期

  8. Excel根据名字批量插入图片

    Excel根据名字批量插入图片 一.如果图片名称与Excel名称不一致时(如下图1) (图1) 1. 先将文件名批量形成文档txt,先新建一个文本文档1.TXT 打开后输入批处理命令:dir . &g ...

  9. excel表格怎么调整行高和列宽_如何在Excel中竖向批量插入图片,这个简单方法你知道吗...

    酌酒与君君自宽,人情翻覆似波澜.白首相知犹按剑,朱门先达笑弹冠.草色全经细雨湿,花枝欲动春风寒.世事浮云何足问,不如高卧且加餐. --[唐]王维<酌酒与裴迪> 不知道大家有没有遇到过这种情 ...

  10. 批量插入图片——《超级处理器》应用

    怎么将下面图片和图片名称批量插入到Excel中,并排列整齐,需要注意的是,里面有三种格式的图片:".jpg",".jpeg",".png". ...

最新文章

  1. 了解 ElasticSearch 这几个知识点后,查询起飞~
  2. Boost:加载评估WebSocket服务器的性能测试程序
  3. COCO数据格式说明
  4. 智慧交通day03-车道线检测实现06:车道线定位及拟合+代码实现
  5. 【洛谷 P2513】 [HAOI2009]逆序对数列(DP)
  6. JQuer实战第一讲:验证用户名是否可用
  7. 中科院分区2020_2020年中科院分区升级版出炉,材料化学物理类一区期刊115本!...
  8. Chrome插件安装 程序包无效
  9. 通信系统仿真速成第2天:QPSK调制与解调(实验)
  10. python折叠代码_使用region注释,将代码块收(折叠)起来
  11. 上海证券交易所云平台移动行情服务测试项目
  12. 关于深度学习优化器 optimizer 的选择,你需要了解这些
  13. 使用cmd命令远程重启服务器
  14. 计算机应用基础实验报告心得体会,计算机应用基础实训总结报告
  15. python输出好看的表格
  16. 被final修饰的部分变量后依然可以被修改
  17. APICloud AVM框架 开发视频会议APP
  18. Kaggle手写数字识别(Digit Recognizer)记录
  19. 指针的指针、字符串和指针、数组指针(详)
  20. java村庄水井_我的世界:它们同样是“水井”却隐藏着不同的“秘密”,见过吗?...

热门文章

  1. cad动态块制作翻转_cad创建动态块实例教程:翻转参数和动作的应用 - CAD自学网...
  2. 禾瘦美学馆,不是谁NB谁做,是谁开店谁NB
  3. MySQL 视图(详解)
  4. 苹果个人开发者账号审核
  5. 蓝桥杯每日一练----字符串逆序
  6. 二进制转十进制python程序_二进制转换(使用Python实现十进制转换器)
  7. web渗透测试----10、信息泄露
  8. html不支持lang属性,html的lang属性学习笔记
  9. 送给天下程序员的诗 (原创)
  10. C语言:数组排序(选择法排序)