Yii2使用phpOffice导出excel报错

薄洪涛5年前PHP2528

线上导出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

相关文章

Yii2.0 jQuery(...).yiiActiveForm is not a function

Yii2.0 jQuery(...).yiiActiveForm is not a function

记一个常见的错误,如下图当我们在view中创建一个activeForm的时候,有时会报这种错误;通常情况下,是jquery重复引入导致的,因为你引入的jquey的版本跟yii2自带jquery版本冲突...

Elasticsearch第二篇之数据操作

    上一篇向大家讲解了Elasticsearch的部署安装和基本设置,这篇文章就和大家一起熟悉下Elastic的数据库操作,和普通数据库不同,es库需要公告...

Yii2.0整合ueditor并上传图片到七牛云

Yii2.0整合ueditor并上传图片到七牛云

某个项目要做一个文章模块,用到Ueditor,并且ue中的图片要上传到七牛,所以总结下步骤;1、Yii2.0下载ueditor for Yii2.0和七牛composer require&n...

Laravel打印sql

在AppServiceProvider.php的boot方法中,增加以下代码DB::listen(     function ($sql) ...

Yii2.0 文件队列的使用

最近做了一个文件上传+处理的功能,需求是这样的,上传并读取.doc文件,并解析里面的内容入库读取文件并入库是使用python处理的,每个文件大约需要处理5-6秒,上传是使用的Yii2,我这里的思路是把...

【转】TCP长连接和短连接区别

【转】TCP长连接和短连接区别

    当网络通信时采用TCP协议时,在真正的读写操作之前,server与client之间必须建立一个连接,当读写操作完成后,双方不再需要这个连接时它们可以释放...

评论列表

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

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

发表评论    

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