XSSFWorkbook获取excel的值,封装成list集合

   
    /**
     * @param wb excel
     * @return sheet集合<row集合<cell集合,全转为String类型>>
     */
    public static List<List<List<String>>> getExcelData(XSSFWorkbook wb){
        int numSheets = wb.getNumberOfSheets();
        List<List<List<String>>> sheets = new ArrayList<>();
        //sheet
        for(int i=0;i<numSheets;i++){
            XSSFSheet sheet = wb.getSheetAt(i);
            System.out.println(sheet.getSheetName());
            int numRows = sheet.getLastRowNum();
            List<List<String>> rows = new ArrayList<>();
            //row
            for (int j=0;j<numRows;j++){
                XSSFRow row = sheet.getRow(j);
                if (row==null){
                    break;
                }
                int numCells = row.getLastCellNum();
                List<String> cells = new ArrayList<>();
                //cell
                for (int k=0;k<numCells;k++){
                   cells.add(getValue(k,row));
                }
                rows.add(cells);
            }
            sheets.add(rows);
        }
        return sheets;
    }
   /**
     * 获取指定位置的数据值,全转为string
     * @param rowNum 所属行, 第一行为0
     * @param colNum 所诉列, 第一列为0
     * @return 值
     */
    public static String getValue(int rowNum, int colNum, XSSFSheet sheet){
        XSSFRow row = sheet.getRow(rowNum);
        return getValue(colNum, row);
    }

    public static String getValue(int colNum, XSSFRow row){
        XSSFCell cell = row.getCell(colNum);
        if (cell==null){
            return "";
        }
        String cellValue = "";
        CellType cellTypeEnum = cell.getCellTypeEnum();
        try {
            DecimalFormat df = new DecimalFormat("0.00");
            if (cell.getCellTypeEnum() == CellType.NUMERIC) {
                if (HSSFDateUtil.isCellDateFormatted(cell)) {
                    cellValue = DateFormatUtils.format(cell.getDateCellValue(), "yyyy-MM-dd");
                } else {
                    NumberFormat nf = NumberFormat.getInstance();
                    cellValue = String.valueOf(nf.format(cell.getNumericCellValue())).replace(",", "");
                }
            } else if (cell.getCellTypeEnum() == CellType.STRING) {
                cellValue = String.valueOf(cell.getStringCellValue());
            } else if (cell.getCellTypeEnum() == CellType.BOOLEAN) {
                cellValue = String.valueOf(cell.getBooleanCellValue());
            } else if (cell.getCellTypeEnum() == CellType.ERROR) {
                cellValue = "错误类型";
            } else if (cell.getCellTypeEnum() == CellType.FORMULA) {//公式类型
                cellValue = df.format(cell.getNumericCellValue());//将公式类型的值转成保留两位小数的数字
//            cellValue = String.valueOf(cell.getArrayFormulaRange().getNumberOfCells());
            } else {
                cellValue = "";
            }
        }catch (Exception e){
            logger.error(e.getMessage(),e);
            cellValue = "-9999999999";
        }
        return cellValue;
    }

  • 9
    点赞
  • 13
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
回答: 如果在使用XSSFWorkbook上传Excel时无法获取到数据,可能有几个可能的原因。首先,确保你使用的是正确的文件格式。XSSFWorkbook是用于处理.xlsx文件的,而不是.xls文件。如果你的文件是.xls格式的,你应该使用HSSFWorkbook。其次,检查你的代码是否正确地读取了Excel文件的内容。你可以使用XSSFWorkbook对象来打开Excel文件,并使用getSheet()方法获取工作表,然后使用getRow()和getCell()方法来获取行和单元格的数据。另外,还要确保你的Excel文件中有数据,并且数据的位置与你的代码中的读取位置相匹配。如果问题仍然存在,可以检查你的代码中是否有其他错误或异常导致无法获取到数据。 #### 引用[.reference_title] - *1* *2* [JAVA使用POI(XSSFWORKBOOK)读取EXCEL文件过程解析](https://blog.csdn.net/weixin_34614567/article/details/114068687)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control,239^v3^insert_chatgpt"}} ] [.reference_item] - *3* [XSSFWorkbook Excel导出导入](https://blog.csdn.net/fuyuanduan/article/details/125895998)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值