在我的项目中,我使用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-07-31 23:02:33
TL;DR -您需要的支持不是在您正在使用的旧的3.9版本中,所以您需要升级到3.13 beta 2或更高版本。
您的问题是,您使用的是Apache的旧版本。这就是当您尝试评估SXSSF单元时会遇到异常的原因。作为公式评估文档接近尾端的详细内容,对于SXSSF公式评估,您需要使用3.13beta 2或更高版本。
需要注意的一点是-公式评估不仅需要在内存中包含公式的单元格,还需要它所引用的任何其他单元格以及它们所引用的任何单元格。因此,调用FormulaEvaluator.evaluateAll()是不太可能的;您通常需要在编写完之后逐个评估单元格。您还将与引用了所有地方的公式做斗争,因为只有当它们所引用的单元格位于当前窗口且尚未被刷新到磁盘时,它们才能工作。
发布于 2015-04-01 12:37:01
只需尝试添加下面的依赖项,看起来您缺少了XSSF的其他jars
<dependency>
<groupId>org.apache.poi</groupId>
<artifactId>poi-ooxml</artifactId>
<version>????</version>
</dependency>发布于 2016-01-25 06:34:18
下面的图像显示了这个问题(在SXSSF中,您无法评估公式)

https://stackoverflow.com/questions/29390924
复制相似问题