java.lang.IllegalStateException: Cannot get a text value from a numeric formula cell序号=====
at org.apache.poi.xssf.usermodel.XSSFCell.typeMismatch(XSSFCell.java:845)
at org.apache.poi.xssf.usermodel.XSSFCell.checkFormulaCachedValueType(XSSFCell.java:302)
at org.apache.poi.xssf.usermodel.XSSFCell.getRichStringCellValue(XSSFCell.java:290)
at org.apache.poi.xssf.usermodel.XSSFCell.getStringCellValue(XSSFCell.java:246)
at Salary.readExcel(Salary.java:87)
at Salary.main(Salary.java:114)大体位置是:
case Cell.CELL_TYPE_FORMULA:
if (!cell.getStringCellValue().equals("")) {
value = cell.getStringCellValue();
} else {
value = cell.getNumericCellValue() + "";
}
break; 添加一段
[color=red]cell.setCellType(Cell.CELL_TYPE_STRING);[/color]
修改为:
case Cell.CELL_TYPE_FORMULA:
cell.setCellType(Cell.CELL_TYPE_STRING);
if (!cell.getStringCellValue().equals("")) {
value = cell.getStringCellValue();
} else {
value = cell.getNumericCellValue() + "";
}
break;

本文讨论了在使用Apache POI库读取Excel文件时遇到的一个常见问题:当尝试从包含公式计算结果的单元格获取文本值时,会抛出IllegalStateException。通过在特定条件下设置单元格类型为字符串,可以避免此类异常并成功读取所需数据。
2162

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



