Java不用POI技術給Word文檔中的Table賦值

 

當在線打開的Word文檔中包含有Table時,如何給Table中的單元格賦值呢?若是是僅僅幾個數據,能夠一個個手動填寫,但如果從數據庫中讀取的大量數據,再想一個個填寫那可就真正讓人頭疼了。因此,當面對大量的數據時,就須要藉助PageOffice開發平臺了。 java

下面我就以生成一張人員信息表爲例,演示一下如何簡單的給Word文檔中的Table賦值。 web

具體步驟以下: 數據庫

第一步:拷貝文件到WEB項目的「WEB-INF/lib」目錄下。拷貝PageOffice示例中下的「WEB-INF/lib」路徑中的pageoffice.cabpageoffice.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");

    //打開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模版文件便可。

相關文章
相關標籤/搜索