博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
fputcsv 导出excel,解决内存、性能、乱码、科学计数法问题
阅读量:5965 次
发布时间:2019-06-19

本文共 865 字,大约阅读时间需要 2 分钟。

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

直接上代码:

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"

转载于:https://blog.51cto.com/12750968/2133076

你可能感兴趣的文章
一个有味道的函数
查看>>
zookeeper在linux环境安装
查看>>
Python_异常和模块
查看>>
【386天】跃迁之路——程序员高效学习方法论探索系列(实验阶段143-2018.02.26)...
查看>>
Java数据类型分类
查看>>
springboot应用启动原理(一) 将启动脚本嵌入jar
查看>>
SpringMVC架构
查看>>
JAVA团队开发手册 - 2.代码管理
查看>>
超详细步骤 | 如何用小程序 SDK 实现电商评价模
查看>>
Android 类库
查看>>
vue和iview应用中的一些问题(持续更新)
查看>>
基于 Workman 实现Web扫描登录
查看>>
karma如何与测试框架合作2之webpack
查看>>
关于VSCode更新对于emmet2.0支持的配置更改问题。
查看>>
二叉树的遍历
查看>>
三元组相加获得target
查看>>
10分钟搭建MySQL Binlog分析+可视化方案
查看>>
vmware虚拟机配置串口
查看>>
小型自动化运维--expect脚本之传递函数
查看>>
多activity中退出整个程序
查看>>