首页 > 作文

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

更新时间:2023-04-07 18:40:39 阅读: 评论:0

    在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: char五帝是谁t=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));    unt($row);}fclo($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);    }lol乌迪尔}

可能出现问题:
乱码问题:转换编码为 gb2312 或 gbk
特殊字符问题:字段后 加 “\t” 或 双引号
数据丢失问题:gb2312 可识别的字符比较少,可以换成 gbk
csv 时间格式筛选: 文本格式的时间无法进行分组筛选,可在 转码的时候进行过滤,如果是时间格式,不转成 文本格式,即 不加 “\t”

文章来源:https://blog.51cto.com忧郁的蓝色/12750968/2133076

本文发布于:2023-04-07 18:40:37,感谢您对本站的认可!

本文链接:https://www.wtabcd.cn/fanwen/zuowen/eebfbd0fe8a9c17f6280886178d878fb.html

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。

本文word下载地址:fputcsv 导出excel,解决内存、性能、乱码、科学计数法问题.doc

本文 PDF 下载地址:fputcsv 导出excel,解决内存、性能、乱码、科学计数法问题.pdf

标签:格式   缓存   时间   数据
相关文章
留言与评论(共有 0 条评论)
   
验证码:
Copyright ©2019-2022 Comsenz Inc.Powered by © 专利检索| 网站地图