做项目的过程中,经常需要把数据里里的数据读出来,经过加工,以word格式输出。 在网上找了很多解决方案都不太理想,偶尔发现了PageOffice,一个国产的Office插件,开发调用非常简单!比网上介绍的poi,jacob等解决方按容易上手多了!功能接口虽然没有poi,jacob那么多,但是满足了一般的需求的百分之八九十,而且不像poi那样还需要区分处理07格式和03格式那么麻烦。
下面是百度百科PageOffice的介绍:
https://baike.baidu.com/item/PageOffice/2737741?fr=aladdin
PageOffice的基本功能包括:
在web网页里打开、编辑、打印预览、打印Word、Excel、PowerPoint等Office文档。
文档并发控制机制。
提供Word修订痕迹、手写批注、圈阅划线、键盘批注、电子印章等OA公文模块的必备功能。
根据数据库动态将数据,包括文本、图片、表格等填充、导出到Word、Excel模板中指定的位置处,并且可以动态指定内容的各种格式。
提取Word、Excel文档中指定位置处的内容,包括文本、图片(Excel暂不支持)、表格等,保存到数据库。
其他功能就不细说了......
更多的接口说明参考PageOffice官网API:http://www.zhuozhengsoft.com/help/java3/index.html
下载地址:http://www.zhuozhengsoft.com/dowm/?
下载PageOffice开发包之后,拷贝 Samples4 文件夹到 Tomcat 的 Webapps 目录下,访问:http://localhost:8080/Samples4/index.html 就会看到所有官方示例效果的列表,重点参考以下几个示例:
一、11、给Word文档中的数据区域(DataRegion)赋值的简单示例
一、17、给Word文档中Table赋值的简单示例
一、18、使用数据标签(DataTag)给Word文件填充文本数据
二、6、后台编程插入Word文件到数据区域
二、7、后台编程插入图片到数据区域
二、8、后台编程插入Excel文件到数据区域
二、9、给Word文档添加水印
二、10、使用数据标签(DataTag)给Word文件填充带格式的数据
二、11、在Word中动态创建数据区域
我们可以写一个简单的程序测试一下效果:
PageOfficeCtrl poCtrl1 = new PageOfficeCtrl(request); poCtrl1.setServerPage(request.getContextPath()+"/poserver.zz"); WordDocument worddoc = new WordDocument(); //先在要插入word文件的位置手动插入书签,书签必须以“PO_”为前缀 //给DataRegion赋值,值的形式为:"纯文本内容、[word]word文件路径[/word]、[image]图片路径[/image]" DataRegion data1 = worddoc.openDataRegion("PO_p1"); data1.setValue("测试字符串");//纯文本内容 DataRegion data2 = worddoc.openDataRegion("PO_p2"); data2.setValue("[word]doc/2.doc[/word]");//插入word文件 DataRegion data3 = worddoc.openDataRegion("PO_p3"); data3.setValue("[image]doc/1.jpg[/image]");//插入图片 //打开文件、填充数据 poCtrl1.setWriter(worddoc); poCtrl1.webOpen("doc/template.doc", OpenModeType.docNormalEdit, "用户名");
代码很简单。短短几句就完成插入文字,图片,子Word文件的功能!不过做项目的话,可以先定义好一个word模板,这样有利于排版,减少编写代码的工作量,也可以调用PageOffice提供的接口控制模板中数据区域的样式,但是编码工作量就增加了。其功能还远不止这些,根据具体需求具体处理吧。