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

最近公司需要每天生成亚马逊广告调价报告报表 并且文件格式必须为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简单

你可能感兴趣的:(php 导出大数据量excel 解决方法 秒出 并不会出现PHPExcel内存溢出问题)