php结合CSV进行数据导出

之前网报系统的导出经常崩溃,用了phpexcel跟js的导出,发现还是因为数据太多,而导致网站崩掉
现在想用php来进行分批次进行导出到一个总的csv中。

<?php

function exportData()
{
    
    	
	//一般就是调用出来的二维关联数组
    $arr = [
        0 => [
            'account' => 1,
            'true_name' => '张三',
        ],
        1 => [
            'account' => 2,
            'true_name' => '李四',
        ],
    ];
	//列名字
    $columns = ['账号','真实姓名'];
    // 限制页面执行时间的
    set_time_limit(0);
	
    ini_set('memory_limit', '1024M');

    header('Content-Description: File Transfer');

    header('Content-Type: application/vnd.ms-excel');
	//导出的文件名
    $filename = urlencode("账号信息导出-".date('Y-m-d', time()).".csv");
    header('Content-Disposition: attachment; filename=' . $filename . '');

    header('Expires: 0');

    header('Cache-Control: must-revalidate');

    header('Pragma: public');        $fp = fopen('php://output', 'a');//打开output流

    //mb_convert_variables('GBK', 'UTF-8', $columns);

    fputcsv($fp, $columns);//将数据格式化为CSV格式并写入到output流中


    //添加查询条件,获取需要的数据

    //获取总数,分页循环处理

    $accessNum = count($arr);
    //echo $accessNum;die;
    $perSize = 1;

    $pages   = ceil($accessNum / $perSize);
    $pages <= 1 && $pages = 1;
    for($i = 1; $i <= $pages; $i++) {
    
    
        foreach($arr as $key => $value) {
    
    
            $value['account'] ="\t" . $value['account'] . "";
            $value['true_name'] ="\t" . $value['true_name'] . "";
            $rowData = $value;                //获取每列数据,转换处理成需要导出的数据

            //需要格式转换,否则会乱码 目前的一般都是utf8了
            //mb_convert_variables('GBK', 'UTF-8', $rowData);
            fputcsv($fp, $rowData);

        }            //释放变量的内存

        unset($db_data);            //刷新输出缓冲到浏览器

        ob_flush();            //必须同时使用 ob_flush() 和flush() 函数来刷新输出缓冲。

        flush();

    }



    fclose($fp);

    exit();

}

exportData();

猜你喜欢

转载自blog.csdn.net/weixin_44088587/article/details/112654770