pageoffice提取Excel表格区域数据

点击可查看视频演示效果

复制代码
注意本文中展示的代码均为关键代码,复制粘贴到您的项目中,按照实际的情况,例如文档路径,用户名等做适当修改即可使用。

在实际的开发过程中,经常会遇到提取Excel文档中数据保存到数据库中的需求,PageOffice客户端控件支持在线保存Excel文件时,打包Excel文档中的指定单元格的数据或所有的数据提交到服务器端,在服务器端创建PageOffice的WorkbookReader对象,就可以获取到Excel单元格中的数据。

后端代码

在后端编写代码调用webOpen方法以表单提交模式xlsSubmitForm打开文件,创建Sheet对象并操作一块区域(Table),并命名,比如:Info。

设置接收处理PageOffice客户端控件提交数据的服务器端后台方法为:saveData

ini 复制代码
PageOfficeCtrl poCtrl = new PageOfficeCtrl(request);

WorkbookWriter workBook = new WorkbookWriter();
SheetWriter sheet = workBook.openSheet("Sheet1");
ExcelTableWriter table = sheet.openTable("B4:F13");//设置Table对象的操作区域
table.setSubmitName("Info");//设置table对象的提交名称,以便保存页面获取提交的数据

poCtrl.setWriter(workBook);//此行必须
poCtrl.setSaveDataPage("saveData");//设置保存数据接口地址
//webOpen的第一个参数支持能够输出下载文件的Url相对地址或者文件在服务器上的磁盘路径两种方式
poCtrl.webOpen("D:\\documents\\test.xlsx", OpenModeType.xlsSubmitForm, "张三");

在服务器端后台方法saveData中,创建com.zhuozhengsoft.pageoffice.excel命名空间中的WorkbookReader对象,提取各单元格数据。您可以在此方法中编写代码,把获取到的数据保存到对应的数据库表中。

ini 复制代码
WorkbookReader workBook = new WorkbookReader(request, response);
SheetReader sheet = workBook.openSheet("Sheet1");
ExcelTableReader table = sheet.openTable("Info");//Info为打开文件时设置的SubmitName
String content = "";
int result = 0;
while (!table.getEOF()) {
    //获取提交的数值
    if (!table.getDataFields().getIsEmpty()) {
        content += "<br/>Product: "
                + table.getDataFields().get(0).getText();
        content += "<br/>Plan: "
                + table.getDataFields().get(1).getText();
        content += "<br/>Real: "
                + table.getDataFields().get(2).getText();
        content += "<br/>Total: "
                + table.getDataFields().get(3).getText();

        if (table.getDataFields().get(2).getText().equals(null)
                || table.getDataFields().get(2).getText().trim().length() == 0
        ) {
            content += "<br/>Rate: 0%";
        } else {
            float f = Float.parseFloat(table.getDataFields().get(2)
                    .getText());
            f = f / Float.parseFloat(table.getDataFields().get(1).getText());
            DecimalFormat df = (DecimalFormat) NumberFormat.getInstance();
            content += "<br/>Rate: " + df.format(f * 100) + "%";
        }
        content += "<br/>*********************************************";
    }
    //循环进入下一行
    table.nextRow();
}
table.close();

//可以在此处编写代码把content输出到控制台,查看提交数据

workBook.close();

原文链接:www.pageoffice.cn/pages/541f3...

相关推荐
Victor3566 小时前
https://editor.csdn.net/md/?articleId=139321571&spm=1011.2415.3001.9698
后端
Victor3566 小时前
Hibernate(89)如何在压力测试中使用Hibernate?
后端
灰子学技术7 小时前
go response.Body.close()导致连接异常处理
开发语言·后端·golang
Gogo8168 小时前
BigInt 与 Number 的爱恨情仇,为何大佬都劝你“能用 Number 就别用 BigInt”?
后端
fuquxiaoguang8 小时前
深入浅出:使用MDC构建SpringBoot全链路请求追踪系统
java·spring boot·后端·调用链分析
毕设源码_廖学姐9 小时前
计算机毕业设计springboot招聘系统网站 基于SpringBoot的在线人才对接平台 SpringBoot驱动的智能求职与招聘服务网
spring boot·后端·课程设计
野犬寒鸦10 小时前
从零起步学习并发编程 || 第六章:ReentrantLock与synchronized 的辨析及运用
java·服务器·数据库·后端·学习·算法
逍遥德11 小时前
如何学编程之01.理论篇.如何通过阅读代码来提高自己的编程能力?
前端·后端·程序人生·重构·软件构建·代码规范
MX_935912 小时前
Spring的bean工厂后处理器和Bean后处理器
java·后端·spring
程序员泠零澪回家种桔子13 小时前
Spring AI框架全方位详解
java·人工智能·后端·spring·ai·架构