在PHP的平常开发中,时常会须要导出 excel ,通常咱们会使用 PHPExcel ,性能强大,可是在数据量大的时候,phpexcel 性能差、内存溢出等各类不可控问题就会出现。所以,若是对导出样式要求不高,咱们能够使用 php 原生的 fputcsv 导出表格,最近项目中,有同事就遇到这个问题,推荐他使用 fputcsv,本着分享的精神,在此记录,但愿可以帮助一些新入行的童鞋。
直接上代码:php
<?php ob_end_clean(); // 文件名 $filename = $type.'_order_'.date('YmdHis').'.csv'; $title = ['单号', '状态', '数量', '商品名', '发货人', '收货人']; // 设置 header 头 header('Content-Type: application/vnd.ms-excel'); // 文件格式 header('Content-Type: charset=utf-8'); // 文件编码 header('Content-Disposition: attachment; filenaeme='. $filename); // 文件名 header('Content-Type: application/octet-stream'); // 二进制流 // header("Accept-Ranges:bytes");// 代表范围单位为字节,可不写 header("Pragma: no-cache"); // 禁止缓存 header("Expires: 0");// 有效期时间 $fp = fopen('php://output','w+'); fputcsv($fp, transCode($title)); // 处理数据 [伪代码] // 若是从数据库获取数据并处理,能够分批进行查询,也能够使用多个文件进行导出 // $result $count = 0; //计数器 $limit = 10000; while ($row = $result->fetchRow()) { $count++; if ($count == $limit) { ob_flush(); // 刷新 php 缓存 flush(); // 刷新输出缓存 $count = 0; // 重置计数器 } // 逐行写入 fputcsv($fp, transCode($row)); unset($row); } fclose($fp); // 编码转换 // 代码通常是 utf-8 格式, csv 导出默认也是 utf-8 格式,而 excel 直接打开默认不识别 utf-8 格式,所以,要导出数据都要进行 格式转换 // 每一个字段后加上 "\t" 能够防止长数字显示为科学计数法 function transCode(array &$arr){ foreach ($arr as &$v) { $v = "\t".iconv('utf-8', 'gb2312//ignore', $v); } }
可能出现问题:
乱码问题:转换编码为 gb2312 或 gbk
特殊字符问题:字段后 加 "\t" 或 双引号
数据丢失问题:gb2312 可识别的字符比较少,能够换成 gbk
csv 时间格式筛选: 文本格式的时间没法进行分组筛选,可在 转码的时候进行过滤,若是是时间格式,不转成 文本格式,即 不加 "\t"数据库