1500字范文,内容丰富有趣,写作好帮手!
1500字范文 > php 导出大数据量excel 解决方法 秒出 并不会出现PHPExcel内存溢出问题

php 导出大数据量excel 解决方法 秒出 并不会出现PHPExcel内存溢出问题

时间:2020-06-14 07:38:58

相关推荐

php  导出大数据量excel 解决方法 秒出 并不会出现PHPExcel内存溢出问题

最近公司需要每天生成亚马逊广告调价报告报表 并且文件格式必须为excel 数据量超过10w+ 使用PHPExcel组件 加上生成器yield 并且设置单元格对象缓存 还是会导致内存爆掉 最后使用了PHP_XLSXWriter 轻量级组件 直接解决内存问题 数据秒出 先介绍一下PHP_XLSXWrite 再贴代码

PHP_XLSXWriter 是一个小而强悍的 Excel 读写插件,它并没有 PHPExcel 功能丰富,很多高级操作比如冻结表头,并不具备,但是它导出速度非常快,非常适合于数据量特别大,下载地址 github . /mk-j/PHP_XLSXWriter 里面有demo 可以自己去看 下面直接上代码

// 导出数据$report_data=[]; //自己脑补//导出路径$path = APPPATH.'excel/manuala_advertise_report/';$file_name = $report['report_name'].'.xlsx';$url=$path.$file_name;require_once APPPATH . '/third_party/PHP_XLSXWriter/PHP_XLSXWriter-master/xlsxwriter.class.php';$header =['Campaign Name'=>'string','Campaign Daily Budget'=>'string','Campaign Start Date'=>'date','Campaign End Date'=>'date','Campaign Targeting Type'=>'string','Ad Group Name'=>'string','Max Bid'=>'string','Keyword'=>'string','Product Targeting ID'=>'string','Match Type'=>'string','SKU'=>'string','Campaign Status'=>'string','Ad Group Status'=>'string','Status'=>'string','Bid+'=>'string'];$writer = new XLSXWriter();$writer->writeSheetHeader('Sheet1', $header);try {foreach ($this->xrangr($report_data, 0, $end) as $value) {//业务处理$list=$value;$writer->writeSheetRow('Sheet1', $list);}$writer->writeToFile($url);}catch (Exception $e){echo $e->getMessage();}

// 生成器yieldpublic function xrangr($report_data,$start, $end, $step = 1){for ($i=$start;$i<=$end;$i +=$step){yield $report_data[$i];}}

就这样完美解决了 代码还比phpexcel简单

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。