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

本文介绍了在PHP开发中,当面对大量数据导出时,如何使用fputcsv代替PHPExcel来避免性能问题和内存溢出。通过设置HTTP头和使用fputcsv函数,可以实现简单的CSV文件导出。文章提供了代码示例,包括编码转换和处理特殊字符,以解决可能遇到的乱码、特殊字符和数据丢失问题。
摘要由CSDN通过智能技术生成

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

直接上代码:

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"

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值