Yii2使用phpOffice导出excel报错

薄洪涛4年前PHP1852

线上导出excel的时候,是不是出现无法访问,如下图

TIM截图20200814215057.png

因为导出的数据量比较大,我怀疑是内存溢出,于是增加了内存分配值,发现仍然报错,于是我查了下日志,如下

2020-08-14 21:31:12 [192.168.8.12][-][-][error][PhpOffice\PhpSpreadsheet\Calculation\Exception] PhpOffice\PhpSpreadsheet\Calculation\Exception: 2020_08_14!K3314 -> Formula Error: An unexpected error occured in /home/www/root/yii2-advanced/vendor/phpoffice/phpspreadsheet/src/PhpSpreadsheet/Cell/Cell.php:274
Stack trace:
#0 /home/www/root/yii2-advanced/vendor/phpoffice/phpspreadsheet/src/PhpSpreadsheet/Writer/Xls/Worksheet.php(443): PhpOffice\PhpSpreadsheet\Cell\Cell->getCalculatedValue()
#1 /home/www/root/yii2-advanced/vendor/phpoffice/phpspreadsheet/src/PhpSpreadsheet/Writer/Xls.php(185): PhpOffice\PhpSpreadsheet\Writer\Xls\Worksheet->close()
#2 /home/www/root/logtest/admin-lte/components/Utils.php(143): PhpOffice\PhpSpreadsheet\Writer\Xls->save('php://output')
#3 /home/www/root/logtest/admin-lte/controllers/VisitInfoController.php(180): app\components\Utils::getExcel('\xB5\xBC\xB3\xF6\xCE\xC4\xBC\xFE_2020_0...', Array, Array)
#4 [internal function]: app\controllers\VisitInfoController->actionExport()
#5 /home/www/root/yii2-advanced/vendor/yiisoft/yii2/base/InlineAction.php(55): call_user_func_array(Array, Array)
#6 /home/www/root/yii2-advanced/vendor/yiisoft/yii2/base/Controller.php(154): yii\base\InlineAction->runWithParams(Array)
#7 /home/www/root/yii2-advanced/vendor/yiisoft/yii2/base/Module.php(454): yii\base\Controller->runAction('export', Array)
#8 /home/www/root/yii2-advanced/vendor/yiisoft/yii2/web/Application.php(84): yii\base\Module->runAction('visit-info/expo...', Array)
#9 /home/www/root/yii2-advanced/vendor/yiisoft/yii2/base/Application.php(375): yii\web\Application->handleRequest(Object(yii\web\Request))
#10 /home/www/root/logtest/admin-lte/web/index.php(19): yii\base\Application->run()
#11 {main}

发现是使用的包报了错,然后百度一番,找到了原因

  1. 导出的单元格内,第一个字符是‘=’,造成PHPExcel解析的时候当成这个单元格的值是由其他单元格计算出来的,后面需要跟着一个合法表达式。如果不是这样,应该在程序中过滤掉。

我们使用ltrim过滤掉就可以了







标签: phpoffice

相关文章

Elasticsearch第三篇之全文搜索及在Yii2.0中的使用

Elasticsearch第三篇之全文搜索及在Yii2.0中的使用

前几天做了一个模块,大数据的搜索,其实也不是特别大,组合起来差不多800万左右,用的是mysql数据库,需求有这么变态的两点;需要按照地址去搜索按照起止时间去搜索别的不说,就这两条,mysql也就只能...

Yii连接postgreSQL及与mysql优劣比较

一、 PostgreSQL 的稳定性极强, Innodb 等引擎在崩溃、断电之类的灾难场景下抗打击能力有了长足进步,然而很多 MySQL 用户都遇到过Server级的数据库丢失的场景——mysql系统...

Yii2.0认证及限流

Yii2.0认证及限流

上次搭建了Yii2.0的接口框架后,现在开始搭建认证和限流模块,先说下这两个模块的作用认证:前后端分离,每次请求都是无状态的,及每一次请求服务器不知道你是谁,你有没有登陆;我们就需要做一个认证模块去识...

谷歌浏览器加载前端资源status=canceled

谷歌浏览器加载前端资源status=canceled

如图,今天在做弹出框(modal中用了iframe)的时候,发现模态框弹出的时候,会有一些前端资源加载被取消,但是也会有加载时间,影响页面的加载速度;然后我尝试用火狐,发现没有这个问题经过一顿goog...

七牛上传报文件已存在

之前做了一个大文件的分片上传,做好之后就没管了,让客户端一直自己用着,然后期间偶尔会有浏览器不兼容的现象我也懒得改,然后十一回来,客户端就给我说,有文件上传不上去,然后正好手头没活,就用改了下先看下思...

workerMan之心跳检测

workerMan之心跳检测

上次咱们说到,长连接应用必须加心跳检测,避免连接由于上时间没有通讯被断开其实心跳的作用有2个:1、客户端定时给服务器发送数据,防止连接由于长时间没有通讯被断开2、服务端可以通过心跳来判断客户端是否在线...

评论列表

访客
2020-08-15 23:18:32

感谢经验分享,佩服解决问题的能力

发表评论    

◎欢迎参与讨论,请在这里发表您的看法、交流您的观点。