背景故事

  今天遇上一个坑,关于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,导致我直接放弃了这个方法,所以才浪费了半天时间去打断点。后来才发现这是个坑,转了类型

之后结果就正确了。

05-28 02:49