java手写excel_最简单的Java导出Excel中的数据

普通的MS Office Excel只能在本地磁盘上打开和编辑保存,这使得程序员在开发项目时受到很多的约束,许多的功能无法实现或者无法达到理想的效果。但是通过调用PageOffice开发平台,不仅可以在线打开并保存Excel文件还可以提交Excel中的数据。

下面我就简单的和大家分享一下如何实现Excel文档的在线打开、编辑、保存和数据的提交。

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

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

poservercom.zhuozhengsoft.pageoffice.poserver.Server

poserver

/poserver.do

poserver

/pageoffice.cab

poserver

/popdf.cab

poserver

/sealsetup.exe

adminseal

com.zhuozhengsoft.pageoffice.poserver.AdminSeal

adminseal

/adminseal.do

adminseal

/loginseal.do

adminseal

/sealp_w_picpath.do

mht

message/rfc822

adminseal-password

123456

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

添加自定义标签库:“”

引入PageOffice类库:“”。

在HTML的

中添加PageOffice引用:

“”,并设置控件所在层(

第三步:Excel.jsp页面编写代码,打开Excel文档。部分代码如下:

PageOfficeCtrl poCtrl =newPageOfficeCtrl(request);

//设置服务器页面

poCtrl.setServerPage("poserver.do");

//定义Workbook对象

Workbook workBook =newWorkbook();

//定义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(),如下:

functionSaveFile() {

document.getElementById("PageOfficeCtrl1").WebSave();

}

如上所述,简单的就实现了Excel文档的在线打开并提交的操作。接下来开始编写保存页面。

第四步:添加保存页面。在网站中添加动态页面SaveData.jsp,在页面中引入PageOffice类库:“”,在后台页面中编写代码处理Excel文档提交的数据,部分代码如下:

Workbook workBook =newWorkbook(request, response);

//打开提交的表单

Sheet sheet = workBook.openSheet("Sheet1");

//打开提交的Table

Table table = sheet.openTable("Info");

//判断是否提交了数据

while(!table.getEOF()) {

//获取提交的数值

if(!table.getDataFields().getIsEmpty()) {

content +="
月份名称:"+ 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文档的转换等等各种操作。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值