`
zi_wu_xian
  • 浏览: 30144 次
社区版块
存档分类
最新评论

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,如下图所示

  

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

分享到:
评论

相关推荐

    Java编程生成word文件设置字体段落格式

    Java对PageOffice编程,从空白的word模板动态生成word文件,填充文本内容、图片,同时设置文本的字体、段落、格式。 PageOffice是标准Java组件,标准JSP Tag标签方式引用,完美支持Eclipse、MyEclipse等开发工具。 ...

    Java根据word 模板,生成自定义内容的word 文件

    Java根据word 模板,生成自定义内容的word 文件案列使用的工具文件

    Java生成excel表格设置公式并填充数据

    Java编程调用PageOffice实现从空白的excel文件动态生成excel表格,设置公式并填充数据。 集成PageOffice不但能够实现在线编辑、保存真正的Office文档,而且还可以轻松实现Word、Excel文档的动态数据填充、格式控制和...

    PageOffice Java 动态填充Word模版

    以生成工资条为例,演示了通过PageOffice开发平台,用Java语言实现Word文档的在线打开、编辑和保存,数据区域数据的动态填充和提交,数据区域插入Word文件,动态填充和提交Word文件中Tabel的数据

    POI读取excel,利用Freemarker建立word模板(带图片),生成word文档,再合并成一个word文档(源码)

    Java语言利用POI读取excel文档,利用Freemarker建立word模板(带图片),excel每一行数据生成单个word文档,再利用POI合并成一个word文档(源码); 博客地址:...

    (简单)struts2下使用pageoffice实现文件在线编辑

    调用PageOffice还可以实现从空白的excel文件动态生成excel表格,设置公式并填充数据。 集成PageOffice不但能够实现在线编辑、保存真正的Office文档,而且还可以轻松实现Word、Excel文档的动态数据填充、格式控制和...

    java后端源码部署-kkFileViewOfficeEdit:文件在线预览及OFFICE(word,excel,ppt)的在线编辑

    java后端源码部署 kkFileViewOfficeEdit 对 进行了二次开发。整合了openOffice进来,项目体积更大了!但使用和配置更简单,只需要配置redis即可 ...PageOffice V4.0 标准版试用序列号:IMTG6-BSXJ-J

    office在线查看

    <%@ page language="java" import="java.lang.String" pageEncoding="UTF-8"%> String path = request.getContextPath(); String getFilePath = request.getParameter("recFileName"); String basePath = request....

    LotusDomino学习笔记(400页涵盖代理和公式使用)

    111. 使用代理生成 XML 284 112. 使用视图生成 XML 286 113. 执行算术运算 288 114. Keep URLs simple by making them relative 292 115. Quick, easy, foolproof field level help 294 116. Hiding attachments ...

    asp.net知识库

    使用 Web 标准生成 ASP.NET 2.0 Web 站点 ASP.NET 2.0基于SQLSERVER 2005的aspnetdb.mdf部署 ASP.NET 2.0 Security FAQs Asp.net 2.0功能体验,细节之Web控件(一) 隐藏控件 Asp.net 2.0功能体验,总体设计思想 Asp...

    FileSaver.js

    FileSaver 类用来接收并保存 PageOfficeCtrl 或 FileMakerCtrl 控件提交的文档。 FileSaver 类用来接收并保存 ...参考网址:http://www.zhuozhengsoft.com/help/java/com/zhuozhengsoft/pageoffice/filesaver.html

    LotusDomino学习笔记.doc

    111. 使用代理生成 XML 284 112. 使用视图生成 XML 286 113. 执行算术运算 288 114. Keep URLs simple by making them relative 292 115. Quick, easy, foolproof field level help 294 116. Hiding attachments ...

    Lotus Domino WEB 开发技术积累-DOC(313页)

    111. 使用代理生成 XML 284 112. 使用视图生成 XML 286 113. 执行算术运算 288 114. Keep URLs simple by making them relative 292 115. Quick, easy, foolproof field level help 294 116. Hiding attachments ...

    Lotus Domino WEB详细 学习笔记

    111. 使用代理生成 XML 284 112. 使用视图生成 XML 286 113. 执行算术运算 288 114. Keep URLs simple by making them relative 292 115. Quick, easy, foolproof field level help 294 116. Hiding ...

    测试培训教材

    把“Sign-On/Sign-Off”中的测试用例“Sign-On Page”添加到测试集中: 切换到“执行流”界面,添加“Sign-On Password”和“Sign-On User Name”两个测试用例: 右键选择“Sign-On User Name”,选择“测试...

Global site tag (gtag.js) - Google Analytics