PHPEXCEL 识别公式问题的问题 和解决方案

phpexcel遇到有公式的单元格(通过其它单元格计算公式得到),读出来的不是值而是公式,有没有什么方法能读出值呢?

如果某个cell使用到了公式
通过getValue()获取的是公式本身
而通过getCalculatedValue()会有对象

通过getFormattedValue()获取到的是公式计算后的值

简单的求和比如sum公式等,这个是没问题的,再比如 复杂的公式VLOOKUP那么就会报错 !

我们来看看:

比如 VLOOKUP公式来获取SKU基础要素的数据

 

通过getCalculatedValue获取公式的值:

 可以看到这个时候报错了,找到这个错误的地方 :

phpExcel\PHPExcel\Cell.php文件:

大概是在 294行抛出异常了,实际上这个值是已经获取到了,那么我们修改如下:

 也就是如果抛出的错误值为"Invalid cell coordinate A",我们还是返回获取的值,不用throw,这个时候我们就可以拿到值了。

 另外目前最新的phpexcel版本是1.8.2,如果要使用公式的话 ,就要在phpExcel\PHPExcel\Cell.php这个文件的大概294行抛出异常的地方添加如下代码:

if($this->_calculatedValue !== NULL && $ex->getMessage()==="Invalid cell coordinate A"){
             return $this->_calculatedValue;
}

不要直接throw,这样就可以获取到复杂公式的值 了。

  • 3
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值