之前网报系统的导出经常崩溃,用了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();