背景故事
今天遇上一个坑,关于poi公式计算结果出错的问题,自己打断点debug了半天,虽然没彻底搞清楚为啥不行,但所幸找到了解决办法。
干货
下面不废话,直接贴干货,原先的公式处理代码如下:
final FormulaEvaluator evaluator = wb.getCreationHelper().createFormulaEvaluator();
switch (cell.getCellType()) {
case Cell.CELL_TYPE_FORMULA:
value += evaluator.evaluate(cell).getNumberValue();
break;
}
之前网上当来的大多代码都是这么写的,但是实际上这里计算A1+A2 这种公式尚且可行,但是遇上SUM(A1:A3)这类的公式就会计算为0,我这里也是打了半天断点想找原因,但是无奈只是找到了原因,没能找到解决办法,各位大佬有兴趣的话可以研究一下。
那么,这个方法解决不了就另外换一个方法,代码如下:
value = "" + cell.getNumericCellValue();//数字结果
这里有一点要注意,一定要转换下类型,由于getNumericCellValue() 这个方法返回的是int类型,所以我刚开始尝试这个方法的时候直接syso这个结果的时候全是0,导致我直接放弃了这个方法,所以才浪费了半天时间去打断点。后来才发现这是个坑,转了类型
之后结果就正确了。