Java不用POI技术给Word文档中的Table赋值

 

当在线打开的Word文档中包含有Table时,如何给Table中的单元格赋值呢?如果是仅仅几个数据,可以一个个手动填写,但若是从数据库中读取的大量数据,再想一个个填写那可就真正让人头疼了。所以,当面对大量的数据时,就需要借助PageOffice开发平台了。

下面我就以生成一张人员信息表为例,演示一下如何简单的给Word文档中的Table赋值。

具体步骤如下:

第一步:拷贝文件到WEB项目的“WEB-INF/lib”目录下。拷贝PageOffice示例中下的“WEB-INF/lib”路径中的pageoffice.cabpageoffice.jar到新建项目的“WEB-INF/lib”目录下。

第二步:修改WEB项目的配置文件。将如下代码添加到配置文件中:

<!-- PageOffice Begin -->

<servlet>

<servlet-name>poserver</servlet-name><servlet-class>com.zhuozhengsoft.pageoffice.poserver.Server

</servlet-class>

</servlet>

<servlet-mapping>

<servlet-name>poserver</servlet-name>

<url-pattern>/poserver.do</url-pattern>

</servlet-mapping>

<servlet-mapping>

    <servlet-name>poserver</servlet-name>

    <url-pattern>/pageoffice.cab</url-pattern>

</servlet-mapping>

<servlet-mapping>

    <servlet-name>poserver</servlet-name>

    <url-pattern>/popdf.cab</url-pattern>

</servlet-mapping>

<servlet-mapping>

    <servlet-name>poserver</servlet-name>

    <url-pattern>/sealsetup.exe</url-pattern>

</servlet-mapping>

<servlet>

<servlet-name>adminseal</servlet-name>

<servlet-class>com.zhuozhengsoft.pageoffice.poserver.AdminSeal

</servlet-class>

</servlet>

<servlet-mapping>

<servlet-name>adminseal</servlet-name>

<url-pattern>/adminseal.do</url-pattern>

</servlet-mapping>

<servlet-mapping>

<servlet-name>adminseal</servlet-name>

<url-pattern>/loginseal.do</url-pattern>

</servlet-mapping>

<servlet-mapping>

<servlet-name>adminseal</servlet-name>

<url-pattern>/sealimage.do</url-pattern>

</servlet-mapping>

<mime-mapping>

    <extension>mht</extension>

    <mime-type>message/rfc822</mime-type>

</mime-mapping>

<context-param>

    <param-name>adminseal-password</param-name>

    <param-value>123456</param-value>

</context-param>

<!-- PageOffice End -->

第三步:添加引用。在WEB项目的WebRoot目录下添加动态页面Word.jsp。在该页面后台代码中

添加自定义标签库:“<%@ taglib uri="http://java.pageoffice.cn" prefix="po"%>

引入PageOffice类库:“<%@page import=” com.zhuozhengsoft.pageoffice.*,com.zhuozhengsoft.pageoffice.wordwriter.*”%>”。

HTML<body>中添加PageOffice引用

<po:PageOfficeCtrl  id="PageOfficeCtrl1"></po:PageOfficeCtrl>,并设置控件所在层(<div></div>)的高和宽。

第四步:Word.jsp后台编写代码。打开Word文件,部分代码如下:

//*******************卓正PageOffice组件的使用***********************

    PageOfficeCtrl poCtrl1 = new PageOfficeCtrl(request);

    poCtrl1.setServerPage("poserver.do"); //此行必须

    WordDocument doc = new WordDocument();

    //打开数据区域,“PO_regTable”为打开的Word文件中插入的书签名称

    DataRegion dataRegion = doc.openDataRegion("PO_regTable");

    //打开tableopenTable(index)方法中的index代表Word文档中table位置的索引,从1开始

    Table table = dataRegion.openTable(1);

    //table中的单元格赋值, openCellRC(int,int)中的参数分别代表第几行、第几列,从1开始

    table.openCellRC(3, 1).setValue("A公司");

    table.openCellRC(3, 2).setValue("开发部");

    table.openCellRC(3, 3).setValue("李清");

    //插入一行,insertRowAfter方法中的参数代表第几行,1开始

    table.insertRowAfter(3);

    table.openCellRC(4, 1).setValue("B公司");

    table.openCellRC(4, 2).setValue("销售部");

    table.openCellRC(4, 3).setValue("张三");

    poCtrl1.setWriter(doc);

    //打开文件 

    poCtrl1.webOpen("doc/test.doc", OpenModeType.docNormalEdit, "张三");

    poCtrl1.setTagId("PageOfficeCtrl1"); //此行必须

说明:上述代码中给单元格所赋的值可以使从数据库中动态读取的数据,当数据库中有多条纪录时只需要循环插入行,并赋值即可。

如上所述,就可轻松简单的实现给Word中的Table赋值了,利用上述方法还可实现生成工资表、考勤表、成绩表等等报表,只需改动打开的Word模版文件即可。

你可能感兴趣的:(Java不用POI技术给Word文档中的Table赋值)