pageoffice连接mysql_[转载]java调用PageOffice生成word

一、在开发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,如下图所示

03e12e65eb3e628e45c78ad740071c63.png

2. 编写代码

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

48304ba5e6f9fe08f3fa1abda7d326ab.png

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");

48304ba5e6f9fe08f3fa1abda7d326ab.png

3. 生成效果图

b3e7a0e4c62920f4fa47ab36dd0a71dc.png

三、 源码下载

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

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值