根据项目需求,客户想生成一个带统计表格、图片和说明文字的word文件,今天整了很久,终于弄好了,下面给出代码,原本想用POI,但找了很久只实现了excel中添加图片的处理,最后不得不使用的是iText2.1.7实现的,最新版不一定好使,附件提供相关jar包
package com.test; import java.awt.Color; import java.io.FileNotFoundException; import java.io.FileOutputStream; import java.io.IOException; import com.lowagie.text.Cell; import com.lowagie.text.Document; import com.lowagie.text.DocumentException; import com.lowagie.text.Font; import com.lowagie.text.Image; import com.lowagie.text.PageSize; import com.lowagie.text.Paragraph; import com.lowagie.text.Table; import com.lowagie.text.rtf.RtfWriter2; public class WordDemo { public WordDemo() { } /** * @param args */ public static void main(String[] args) { WordDemo.createDoc(); } /** * 创建word文档 步骤: 1,建立文档 2,创建一个书写器 3,打开文档 4,向文档中写入数据(表格,图片) 5,关闭文档 */ public static void createDoc() { // 创建word文档,并设置纸张的大小 Document document = new Document(PageSize.A4); try { RtfWriter2.getInstance(document, new FileOutputStream("E:/word.doc")); document.open(); // 设置合同头 Paragraph ph = new Paragraph(); Font f = new Font(); Paragraph p = new Paragraph("出口合同", new Font(Font.NORMAL, 18,Font.BOLDITALIC, new Color(0, 0, 0))); p.setAlignment(1); document.add(p); ph.setFont(f); // 设置中文字体 // BaseFont bfFont = BaseFont.createFont("STSongStd-Light","UniGB-UCS2-H", BaseFont.NOT_EMBEDDED); // Font chinaFont = new Font(); /* * 创建有三列的表格 */ Table table = new Table(4); document.add(new Paragraph("生成表格")); table.setBorderWidth(1); table.setBorderColor(Color.BLACK); table.setPadding(0); table.setSpacing(0); /* * 添加表头的元素 */ Cell cell = new Cell("表头");// 单元格 cell.setHeader(true); cell.setColspan(3);// 设置表格为三列 cell.setRowspan(3);// 设置表格为三行 table.addCell(cell); table.endHeaders();// 表头结束 // 表格的主体 cell = new Cell("Example cell 2"); cell.setRowspan(2);// 当前单元格占两行,纵向跨度 table.addCell(cell); table.addCell("1,1"); table.addCell("1,2"); table.addCell("1,3"); table.addCell("1,4"); table.addCell("1,5"); table.addCell(new Paragraph("用java生成的表格1")); table.addCell(new Paragraph("用java生成的表格2")); table.addCell(new Paragraph("用java生成的表格3")); table.addCell(new Paragraph("用java生成的表格4")); document.add(new Paragraph("用java生成word文件")); document.add(table); /* 测试添加一张图片 */ Image img = Image.getInstance("E:/ok.png"); document.add(img); /* 测试再添加一张图片 */ Image img2 = Image.getInstance("E:/ok.png"); document.add(img2); document.close(); } catch (FileNotFoundException e) { e.printStackTrace(); } catch (DocumentException e) { e.printStackTrace(); } catch (IOException e) { e.printStackTrace(); } } }
相关推荐
使用poi替换word中的图片,无需加书签,doc/docx均可,亲测。
Freemarker+poi 模板生成word+导入图片 直接导入eclipse即可,希望对大家有所帮助
poi导入word,代码简单包含pom文件
POI对Word的操作,特别是针对生成报告模板时,向word中写入文本和图片。
使用poi替换word中的文字和图片实现打印,注意代码中的jar包、图片、word位置
POI可以实现Word,Exce的导入导出。可以进行jxl的升级,来解决版本低的问题。
里面包含图片转码的jar包,项目中使用的
java实现word、excel在线预览。版本2003和2007都支持在线预览,项目需要导入一些poi相关的jar,jar之间的版本有要求。在我的资源列表,有相关的jar包可以下载。
通过POI将图片插入word文档中,写文字就简单了自己摸索
java_poi实现excel导入导出功能,有详细的注解
里面有工具类,包含word和excel。支持doc。docx xls和xlsx等格式。还有稀缺的所有jar包。绝对物有所值
主要介绍了java poi设置生成的word的图片为上下型环绕以及其位置的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
Apache poi 根据word模板生成word报表 替换 循环列表 图片,代码调试过了,修改相应的图片位置,word模板路径即可运行
主要是springboot+myBatis+poi+mysql的使用,从数据库查询到结果集导出excel到本地,从本地中的excel文件导入到数据库中。
poi导出word例子(图片)
通过代码,详细介绍使用Apache 2008-12-01发布的poi包,实现Excel2007的操作。
1、poi版本3.13 2、可进行表格替换。复制、图片导出 3、可直接运行
利用POI实现Excel的导入和导出实例的实现,外加poi的全部jar包
用poi实现的excel导入导出,进行了很好的封装
POI解析word2007文本及图片(已测试).doc