poi导入excel获取一个脚码整页的所有数据

该博客介绍如何通过前端HTML表单上传Excel文件,然后使用Java的POI库在后台获取指定页码的数据。示例代码展示了如何处理上传事件,并在成功上传后调用`getAllSheet`方法获取第一页的所有数据。如果数据为空,则返回提示信息,否则遍历并打印每行的第一个字段。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

页面:

<form id="editModelFormfour" class="easyui-form" method="POST" enctype="multipart/form-data" >
<input type="file" name="fileName" class="file" id="fileUp" accept=".xls, .xlsx" onchange="document.getElementById('textfield').value=this.value" />
<button type="button" class="btn btn-default" style="margin-left: 0; margin: 0px;" onclick="searchModel()">
                    确认
</button>

</form>

<script type="text/javascript">
function searchModel(){
        if($("#fileUp").val()==""){
            alert("请导入文件!");
        }else{
            $('#editModelFormfour').form('submit',{
                url : '${pageContext.request.contextPath}/excelOperate/gainExcelContract.action',
                success : function(string) {
                         console.log('变量:',string);
                          alert(string);
                    }
                });
        }
    }

</script>


后台:

public List<Map<String,Object>> getAllSheet(MultipartFile fileName//上传过来的excel,int sheetnum//页面脚码) throws IOException{

        int lastRowNum;    
        int physicalNumberOfRows;
        List<Map<String, Object>> allSheet = new ArrayList<Map<String,Object>>();
        try {
            HSSFWorkbook wb = new HSSFWorkbook(fileName.getInputStream());
            HSSFSheet sheet = wb.getSheetAt(sheetnum);
            lastRowNum = sheet.getLastRowNum();
            physicalNumberOfRows = sheet.getRow(0).getPhysicalNumberOfCells();
            allSheet = getAllHSheet(sheet,lastRowNum,physicalNumberOfRows,sheetnum);
        } catch (Exception e) {
            XSSFWorkbook wb = new XSSFWorkbook(fileName.getInputStream());
            XSSFSheet sheet = wb.getSheetAt(sheetnum);
            lastRowNum = sheet.getLastRowNum();
            physicalNumberOfRows = sheet.getRow(0).getPhysicalNumberOfCells();
            allSheet = getAllXSheet(sheet,lastRowNum,physicalNumberOfRows,sheetnum);
        }
        return allSheet;//返回整个页面的内容

    }


取值:

List<Map<String, Object>> allSheet = getAllSheet(fileName,0);//或得到第一页的所有数据
        
        if (allSheet.size()==0){
            return "数据为空!!";//没有数据
        }else{

            for(int i=1;i<allSheet.size();i++){//获得行

                System.out.pringtln(allSheet.get(i).get("0").toString());//输出每一行数据的第一个字段

            }


注:未经允许不得转载。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值