public function export(){ header('Content-Type: application/vnd.ms-excel'); header('Content-Disposition: attachment;filename=xxxxxxxxx.csv'); header('Cache-Control: max-age=0'); set_time_limit(0); // 设置脚本最大执行时间 为0 //ini_set('memory_limit','200M'); // 临时设置最大内存占用 //关闭缓冲区 $flag = ob_end_clean(); if (!$flag) { die("关闭缓冲区错误"); } $startTime = microtime(true); //$status = ob_get_status(); //file_put_contents("11.log", var_export($status, 1).PHP_EOL, 8); // 打开PHP文件句柄,php://output 表示直接输出到浏览器 $fp = fopen('php://output', 'a'); $column_name = ["ID", "姓名", "手机号", "描述", "添加时间"]; // 将中文标题转换编码,否则乱码 // foreach ($column_name as $i => $v) { // $column_name[$i] = iconv('utf-8', 'GBK', $v); // } // 将标题名称通过fputcsv写到文件句柄 fputcsv($fp, $column_name); $export_data = []; $start = 0; $limit = 5000000; $column_name = db('test_export')->limit($start,$limit)->select(); if(empty($column_name) || !$column_name){ break; } if($start >5){ break; } foreach ($column_name as $k => $v) { $export_data[] = [ $v['id'], $v['name'],$v['phone'],$v['des'],$v['addtime'] ]; } foreach ($export_data as $item) { $rows = array(); foreach ($item as $export_obj) { $rows[] = iconv('utf-8', 'GBK', $export_obj); } fputcsv($fp, $rows); } $export_data = []; //重新复制,释放掉旧数据 $start += $limit; fclose($fp); exit(0); }
php使用fputcsv进行大数据的导出
最新推荐文章于 2024-06-26 08:46:08 发布