fputcsv 导出excel,解决内存性能乱码科学计数法问题

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了fputcsv 导出excel,解决内存性能乱码科学计数法问题相关的知识,希望对你有一定的参考价值。

php的日常开发中,时常会需要导出 excel ,一般我们会使用 PHPExcel ,性能强大,但是在数据量大的时候,phpexcel 性能差、内存溢出等各种不可控问题就会出现。因此,如果对导出样式要求不高,我们可以使用 php 原生的 fputcsv 导出表格,最近项目中,有同事就遇到这个问题,推荐他使用 fputcsv,本着分享的精神,在此记录,希望能够帮助一些新入行的童鞋。

直接上代码:

<?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 格式,因此,要导出数据都要进行 格式转换
// 每个字段前加上 "	" 可以防止长数字显示为科学计数法 
function transCode(array &$arr){
    foreach ($arr as &$v) {
        $v = "	".iconv(‘utf-8‘, ‘gb2312//ignore‘, $v);
    }
}

临时写的 demo ,如错误还请指教

以上是关于fputcsv 导出excel,解决内存性能乱码科学计数法问题的主要内容,如果未能解决你的问题,请参考以下文章

PHP 高效导入导出Excel(csv)方法之fgetcsv()和fputcsv()函数

jxl导出excel出现乱码怎么解决

PHP导出100万数据到excel

arcmap导出excel为乱码 excel为乱码解决办法

phpexcel导出文件后,wps能用 excel打开乱码解决

linux导出csv在windows下看是乱码?请问如何解决