普通的MS Office Excel只能在本地磁盘上打开和编辑保存,这使得程序员在开发项目时受到很多的约束,许多的功能无法实现或者无法达到理想的效果。但是通过调用PageOffice开发平台,不仅可以在线打开并保存Excel文件还可以提交Excel中的数据。
下面我就简单的和大家分享一下如何实现Excel文档的在线打开、编辑、保存和数据的提交。
第一步:拷贝文件到WEB项目的“WEB-INF/lib”目录下。拷贝PageOffice示例中下的“WEB-INF/lib”路径中的pageoffice.cab和pageoffice.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>/sealp_w_picpath.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目录下添加动态页面Excel.jsp。在该页面后台代码中
添加自定义标签库:“<%@ taglib uri="http://java.pageoffice.cn" prefix="po"%>”
引入PageOffice类库:“<%@page import=” com.zhuozhengsoft.pageoffice.*,com.zhuozhengsoft.pageoffice.excelwriter.*”%>”。
在HTML的<body>中添加PageOffice引用:
“<po:PageOfficeCtrlid="PageOfficeCtrl1"></po:PageOfficeCtrl>”,并设置控件所在层(<div></div>)的高和宽。
第三步:Excel.jsp页面编写代码,打开Excel文档。部分代码如下:
PageOfficeCtrl poCtrl = new PageOfficeCtrl(request);
//设置服务器页面
poCtrl.setServerPage("poserver.do");
//定义Workbook对象
Workbook workBook = new Workbook();
//定义Sheet对象,"Sheet1"是打开的Excel表单的名称
Sheet sheet = workBook.openSheet("Sheet1");
//定义table对象,设置table对象的设置范围
Table table = sheet.openTable("B4:F13");
//设置table对象的提交名称,以便保存页面获取提交的数据
table.setSubmitName("Info");
poCtrl.setWriter(workBook);
//添加自定义按钮
poCtrl.addCustomToolButton("保存", "Save", 1);
//设置保存页面
poCtrl.setSaveDataPage("SaveData.jsp");
//打开Word文档
poCtrl.webOpen("doc/test.xls", OpenModeType.xlsSubmitForm, "张佚名");
poCtrl.setTagId("PageOfficeCtrl1");//此行必需
说明:若想提交数据需将webOpen方法的第二个参数属性OpenModeType的类型设置为xlsSubmitForm提交类型
在Excel.jsp页面添加JS函数Save(),如下:
function SaveFile() {
document.getElementById("PageOfficeCtrl1").WebSave();
}
如上所述,简单的就实现了Excel文档的在线打开并提交的操作。接下来开始编写保存页面。
第四步:添加保存页面。在网站中添加动态页面SaveData.jsp,在页面中引入PageOffice类库:“<%@page import=” com.zhuozhengsoft.pageoffice.*, com.zhuozhengsoft.pageoffice.excelreader.*”%>”,在后台页面中编写代码处理Excel文档提交的数据,部分代码如下:
Workbook workBook = new Workbook(request, response);
//打开提交的表单
Sheet sheet = workBook.openSheet("Sheet1");
//打开提交的Table
Table table = sheet.openTable("Info");
//判断是否提交了数据
while (!table.getEOF()) {
//获取提交的数值
if (!table.getDataFields().getIsEmpty()) {
content += "<br/>月份名称:"+ table.getDataFields().get(0).getText();
... ...
... ...
}
//循环进入下一行
table.nextRow();
}
table.close();
workBook.close();
说明:table.getDataFields()获取的是提交过来的table中的数据。table.getDataFields().size()获取得是Table中的列数而非行数。
至此,就简单的实现了Excel文档的在线打开、编辑、保存和提交数据了。
方案总结:
上述的示例主要是借助了 PageOffice 开发平台的 PageOfficeCtrl 控件,利用该控件还可实现在 Excel 文件中添加手写批注、加盖电子印章等功能。另外,在 PageOffice 平台下还可实现 Word 、 PPT 、 PDF 等文档的在线打开、编辑保存, Word 文档到 PDF 文档的转换等等各种操作。