zoukankan      html  css  js  c++  java
  • 关于poi的坑

      背景故事

      今天遇上一个坑,关于poi公式计算结果出错的问题,自己打断点debug了半天,虽然没彻底搞清楚为啥不行,但所幸找到了解决办法。

      干货

      下面不废话,直接贴干货,原先的公式处理代码如下:

      

     1 final FormulaEvaluator evaluator = wb.getCreationHelper().createFormulaEvaluator();
     2 switch (cell.getCellType()) {
     3   case Cell.CELL_TYPE_FORMULA:
     4         value += evaluator.evaluate(cell).getNumberValue();
     5         break;
     6    }                                    

      之前网上当来的大多代码都是这么写的,但是实际上这里计算A1+A2 这种公式尚且可行,但是遇上SUM(A1:A3)这类的公式就会计算为0,我这里也是打了半天断点想找原因,但是无奈只是找到了原因,没能找到解决办法,各位大佬有兴趣的话可以研究一下。

      那么,这个方法解决不了就另外换一个方法,代码如下:

     value = "" + cell.getNumericCellValue();//数字结果

      这里有一点要注意,一定要转换下类型,由于getNumericCellValue() 这个方法返回的是int类型,所以我刚开始尝试这个方法的时候直接syso这个结果的时候全是0,导致我直接放弃了这个方法,所以才浪费了半天时间去打断点。后来才发现这是个坑,转了类型

    之后结果就正确了。

  • 相关阅读:
    构造函数
    Php基础知识测试题答案与解释
    bootstrap简介
    ajax删除数据(不跳转页面)
    ajax基础部分
    Jquery弹出窗口
    JSON
    Jquery之JSON的用法
    Jquery基本用法
    php购物车(练习)
  • 原文地址:https://www.cnblogs.com/Oliver-rebirth/p/poi_formula.html
Copyright © 2011-2022 走看看