1.遇事不要慌,先百度翻译一下
处理java.lang.IllegalStateException:无法
从数字单元格中获取文本值
2.原因分析
1.单元格默认将单元格里面的内容解析成数字形式,你后端接受单元格是row.getCell(j).getStringCellValue(),
3.解决办法
<1>在excel文件中有数字的单元格前面加上 ‘ ,这个大家应该明白什么意思(这个一般不建议)
<2>在程序中进行类型转换,只要加上
row.getCell(j).setCellType(Cell.CELL_TYPE_STRING); 程序运行到row.getCell(j).getStringCellValue()就不会再出错
<3>如果不知道单元格到底传什么格式,那就进行类型判断
自己去类型就可以,代码可以自己修改
String cellValue = "";
int cellType=cell.getCellType();
if(cellType==Cell.CELL_TYPE_FORMULA){ //表达式类型
cellType=evaluator.evaluate(cell).getCellType();
}
switch (cellType) {
case Cell.CELL_TYPE_STRING: //字符串类型
cellValue= cell.getStringCellValue().trim();
cellValue=StringUtils.isEmpty(cellValue) ? "" : cellValue;
break;
case Cell.CELL_TYPE_BOOLEAN: //布尔类型
cellValue = String.valueOf(cell.getBooleanCellValue());
break;
case Cell.CELL_TYPE_NUMERIC: //数值类型
if (HSSFDateUtil.isCellDateFormatted(cell)) { //判断日期类型
cellValue = DateUtil.formatDateByFormat(cell.getDateCellValue(), "yyyy-MM-dd");
} else { //否
cellValue = new DecimalFormat("#.######").format(cell.getNumericCellValue());
}
break;
default: //其它类型,取空串吧
cellValue = "";
break;
}
return cellValue;
}

本文介绍了解决在Java中从Excel单元格获取文本值时出现的java.lang.IllegalStateException异常的方法。通过设置单元格类型为字符串或进行类型判断与转换,确保程序能够正确读取Excel中的数据。
2163

被折叠的 条评论
为什么被折叠?



