在我的项目中,我使用SXSSFWorkbook (ApachePOI3.9)类来管理大型电子表格。现在我需要计算一些单元格的公式,所以我尝试使用这样的FormulaEvaluator
...
SXSSFWorkbook streamingWorkbook = new SXSSFWorkbook(100);
...
FormulaEvaluator fe = streamingWorkbook.getCreationHelper().createFormulaEvaluator();
...
fe.evaluateInCell(cell);但是这样做,就会引发异常。
java.lang.ClassCastException: org.apache.poi.xssf.streaming.SXSSFCell cannot be cast to org.apache.poi.xssf.usermodel.XSSFCell
at org.apache.poi.xssf.usermodel.XSSFFormulaEvaluator.evaluateInCell(XSSFFormulaEvaluator.java:177)
at org.apache.poi.xssf.usermodel.XSSFFormulaEvaluator.evaluateInCell(XSSFFormulaEvaluator.java:44)..。
造成此错误的直接原因是明确的:.evaluateInCell方法接受Cell对象,但在内部将Cell转换为XSSFCell。因为我要传递一个SXSSFCell,所以会抛出异常。
因此,问题是:是否有一种在流工作簿(SXSSF)中实现公式评估的方法?
发布于 2015-04-01 12:37:01
只需尝试添加下面的依赖项,看起来您缺少了XSSF的其他jars
<dependency>
<groupId>org.apache.poi</groupId>
<artifactId>poi-ooxml</artifactId>
<version>????</version>
</dependency>https://stackoverflow.com/questions/29390924
复制相似问题