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简单

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值