关于POI导入Excel表时报:java.lang.IllegalStateException: Cannot get a text value from a numeric cell

1. 问题描述:    POI技术来实现Excel表格数据导入到系统中的时候 ,单元格中的数据类型不是String类型的时候,执行row.getCell(0).getStringCellValue()然后再进行实体属性的set方法时,会报:Cannot get a text value from a numeric cell异常.

代码如下:  

            waybill.setId(Integer.parseInt(row.getCell(0).getStringCellValue()));

异常如下:



2. 分析原因:

当我们试图从一个数字类型的Cell读取出一个字符串需要设置类型

故将此类型的单元格的数据类型转成string.    然后就可以把纯数字作为String类型读进来了,再进行后面设置操作..

代码如下:

                Cell cell0 = row.getCell(0);
cell0.setCellType(Cell.CELL_TYPE_STRING);
waybill.setId(Integer.parseInt(cell0.getStringCellValue()));

3. 结束!


该异常通常在使用POI库中的getStringCellValue()方法时出现,因为该方法只能用于获取单元格中的字符串类型值,如果单元格中的值不是字符串类型,就会抛出该异常。例如,如果单元格中的值是数字类型,而你使用getStringCellValue()方法来获取该单元格的值,就会抛出java.lang.IllegalStateException: Cannot get a STRING value from a NUMERIC cell异常。 解决该异常的方法是,首先使用getCellType()方法来获取单元格的类型,然后根据单元格的类型来选择使用相应的方法来获取单元格的值。例如,如果单元格的类型是数字类型,就可以使用getNumericCellValue()方法来获取该单元格的值。 以下是一个使用POI库来获取单元格值的例子: ```java // 创建工作簿对象 Workbook workbook = new XSSFWorkbook(new FileInputStream("example.xlsx")); // 获取第一个工作 Sheet sheet = workbook.getSheetAt(0); // 获取第二行第三列的单元格 Cell cell = sheet.getRow(1).getCell(2); // 判断单元格的类型 if (cell.getCellType() == CellType.STRING) { // 如果单元格的类型是字符串类型,就使用getStringCellValue()方法来获取单元格的值 String value = cell.getStringCellValue(); System.out.println("单元格的值是:" + value); } else if (cell.getCellType() == CellType.NUMERIC) { // 如果单元格的类型是数字类型,就使用getNumericCellValue()方法来获取单元格的值 double value = cell.getNumericCellValue(); System.out.println("单元格的值是:" + value); } ```
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值