最近公司需要每天生成亚马逊广告调价报告报表 并且文件格式必须为excel 数据量超过10w+ 使用PHPExcel组件 加上生成器yield 并且设置单元格对象缓存 还是会导致内存爆掉 最后使用了PHP_XLSXWriter 轻量级组件 直接解决内存问题 数据秒出 先介绍一下PHP_XLSXWrite 再贴代码
PHP_XLSXWriter 是一个小而强悍的 Excel 读写插件,它并没有 PHPExcel 功能丰富,很多高级操作比如冻结表头,并不具备,但是它导出速度非常快,非常适合于数据量特别大,下载地址 github . https://github.com/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();
}
// 生成器yield
public function xrangr($report_data,$start, $end, $step = 1){
for ($i=$start;$i<=$end;$i +=$step){
yield $report_data[$i];
}
}
就这样完美解决了 代码还比phpexcel简单