大佬教程收集整理的这篇文章主要介绍了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();
以上是大佬教程为你收集整理的php结合CSV进行数据导出全部内容,希望文章能够帮你解决php结合CSV进行数据导出所遇到的程序开发问题。
如果觉得大佬教程网站内容还不错,欢迎将大佬教程推荐给程序员好友。
本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。