[原创]java调用PageOffice生成word

2018-06-18 01:23:41来源:未知 阅读 ()

新老客户大回馈,云服务器低至5折

一、在开发OA办公或与文档相关的Web系统中,难免会遇到动态生成word文档的需求,为了解决工作中遇到导出word文档的需求,前一段时间上网找了一些资料,在word导出这方面有很多工具可以使用,jacob、poi、java2word、itext。jacob要求服务器必须是windows操作系统,服务器上还必须安装office软件,果断放弃!poi需要针对doc和docx两种格式写不同的代码,增加了程序的复杂度。java2doc 是对 jacob 的封装,同样放弃!最后选定了用itext来导出word,网上一些资料说itext导出word功能太简单,通过试用之后,封装工具类,使用起来确实挺方便,但是导出的word文档在细节方面很难达到要求,比如:字体、行距、字体间距、首行缩进等。

二、由于itext导出的word有各种各样的小问题,只能另找其他的解决方案,经过一个朋友推荐,可用PageOffice组件来导出word,其效果能与用户需求的word文档达到完美的一致,而且编程接口简单,调用很方便。总的来说就是制作模板(用PO_开头的书签作为数据占位符),然后编程调用PageOffice接口用真实数据替换模板中的占位符,最后生成word。下面看例子:

1. 制作模板

  打开word模板插入书签:PO_Dept、PO_Name、PO_Cause、PO_Num、PO_Date,如下图所示

  

2. 编写代码

  调用PageOffice接口,给word模板填充数据生成word文档:

  

 1     // 声明变量存储从数据库中读取的数据
 2     String  docName = "", docDept = "", docCause = "", docNum = "", docDate = "";
 3     // 数据库数据读取操作(不同的数据库用不同的代码)
 4     ResultSet rs = stmt.executeQuery("select * from leaveRecord where ID = " + id);
 5     if (rs.next()) {
 6         docName = rs.getString("Name");
 7         docDept = rs.getString("Dept");
 8         docCause = rs.getString("Cause");
 9         docNum = rs.getString("Num");
10         docDate = rs.getString("SubmitTime");
11     }
12     rs.close();
13     //创建PageOffice的WordDocument对象,操作Word文件
14     WordDocument doc = new WordDocument();
15     doc.openDataRegion("PO_name").setValue(docName);
16     doc.openDataRegion("PO_dept").setValue(docDept);
17     doc.openDataRegion("PO_cause").setValue(docCause);
18     doc.openDataRegion("PO_num").setValue(docNum);
19     doc.openDataRegion("PO_date").setValue(docDate);
20     //创建PageOfficeCtrl对象打开文件
21     PageOfficeCtrl poCtrl1 = new PageOfficeCtrl(request);
22     poCtrl1.setServerPage(request.getContextPath()+"/poserver.zz"); //此行必须
23     //获取数据对象
24     poCtrl1.setWriter(doc);
25     // 打开文档
26     poCtrl1.webOpen("doc/template.doc", OpenModeType.docReadOnly, "Tom");

3. 生成效果图

  

  

三、 源码下载

  https://download.csdn.net/download/zi_wu_xian/10399345

标签:

版权申明:本站文章部分自网络,如有侵权,请联系:west999com@outlook.com
特别注意:本站所有转载文章言论不代表本站观点,本站所提供的摄影照片,插画,设计作品,如需使用,请与原作者联系,版权归原作者所有

上一篇:Java杂记9—NIO

下一篇:021.7 装饰设计模式