當在線打開的Word文檔中包含有Table時,如何給Table中的單元格賦值呢?若是是僅僅幾個數據,能夠一個個手動填寫,但如果從數據庫中讀取的大量數據,再想一個個填寫那可就真正讓人頭疼了。因此,當面對大量的數據時,就須要藉助PageOffice開發平臺了。 java
下面我就以生成一張人員信息表爲例,演示一下如何簡單的給Word文檔中的Table賦值。 web
具體步驟以下: 數據庫
第一步:拷貝文件到WEB項目的「WEB-INF/lib」目錄下。拷貝PageOffice示例中下的「WEB-INF/lib」路徑中的pageoffice.cab和pageoffice.jar到新建項目的「WEB-INF/lib」目錄下。 app
第二步:修改WEB項目的配置文件。將以下代碼添加到配置文件中: jsp
<!-- PageOffice Begin --> url
<servlet> spa
<servlet-name>poserver</servlet-name><servlet-class>com.zhuozhengsoft.pageoffice.poserver.Server .net
</servlet-class> orm
</servlet> server
<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");
//打開table,openTable(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模版文件便可。