最近公司需要每天生成亚马逊广告调价报告报表 并且文件格式必须为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简单
如果觉得《php 导出大数据量excel 解决方法 秒出 并不会出现PHPExcel内存溢出问题》对你有帮助,请点赞、收藏,并留下你的观点哦!