场景和痛点

说明

我们工作场景都常会导出相关的excel数据,有时候需要大量的数据,10W,100W都有可能

我们现有方案都是直接利用phpexcel等类库来操作,phpexcel的load加载或是写入一次导出会遇到超时内存和时间限制问题,就算我们ini_set依旧不是最好的方案

下面我们利用php输出csv,把数据依次输出清空再输出的方式到输出终端(浏览器访问就是浏览器输出)

编写过程

说明

关键具体在代码里注释

代码


<?php
/**
* Created by PhpStorm.
* User: qkl
* Date: 2018/7/11
* Time: 13:28
*/
ini_set('display_errors', 1);
//error_reporting(E_ALL); function convert($size)
{
$unit = array('b', 'kb', 'mb', 'gb', 'tb', 'pb');
return @round($size / pow(1024, ($i = floor(log($size, 1024)))), 2) . ' ' . $unit[$i];
} header('Content-Type: application/vnd.ms-excel');
header('Content-Disposition: attachment;filename=xxxxxxxxx.csv');
header('Cache-Control: max-age=0'); set_time_limit(0); // 设置脚本最大执行时间 为0
//ini_set('memory_limit','200M'); // 临时设置最大内存占用 //关闭缓冲区
$flag = ob_end_clean();
if (!$flag) {
die("关闭缓冲区错误");
} $startTime = microtime(true); //$status = ob_get_status();
//file_put_contents("11.log", var_export($status, 1).PHP_EOL, 8); // 打开PHP文件句柄,php://output 表示直接输出到浏览器
$fp = fopen('php://output', 'a'); $column_name = ["XXX", "XXX", "XXX", "XXX", "XXX", "XXX", "XXX", "XXX", "XXX", "XXX"];
// 将中文标题转换编码,否则乱码
foreach ($column_name as $i => $v) {
$column_name[$i] = iconv('utf-8', 'GBK', $v);
} // 将标题名称通过fputcsv写到文件句柄
fputcsv($fp, $column_name); $export_data = [];
for ($i = 0; $i < 10; $i++) {
foreach (range(1, 100000) as $k => $v) {
$export_data[] = [
"XXX" . $v, "XXX" . $v, "XXX" . $v, "XXX" . $v, "XXX" . $v, "XXX" . $v, "XXX" . $v, "XXX" . $v, "XXX" . $v, "XXX" . $v
];
}
foreach ($export_data as $item) {
$rows = array();
foreach ($item as $export_obj) {
$rows[] = iconv('utf-8', 'GBK', $export_obj);
}
fputcsv($fp, $rows);
} $export_data = []; //重新复制,释放掉旧数据
}
fclose($fp); $endTime = microtime(true);
$memoryUse = memory_get_usage(); file_put_contents("11.log", "内存占用:" . convert($memoryUse) . "; 用时:" . ($endTime - $startTime) . PHP_EOL, 8); exit(0);

结果

测试说明

我们模拟数据,输入了100万(10000 * 10)数据

日志记录内存使用率


# 文件大小:84.7 MB (88,889,540 字节)
# 这里的用时因为业务模拟,所以具体根据操作业务数据可能会更长,内存占用同理 内存占用:118.99 kb; 用时:74.375253915787

原文地址:https://segmentfault.com/a/1190000015601266

最新文章

  1. Vue ES6 Jade Scss Webpack Gulp
  2. 精通CSS version2笔记之⒈选择器
  3. Can’t connect to local MySQL server through socket ‘/var/lib/mysql/mysql.sock’解决方法 + Linux启动/停止/重启Mysql数据库的方法
  4. Lua学习笔记(四):表和数组
  5. 9、第九节课jquery选择器jq2,20151007
  6. 机器人操作系统ROS | 简介篇
  7. 转:ASP.Net MVC:校验、AJAX与过滤器
  8. BCD码、十六进制与十进制互转
  9. CentOS和Redhat发行版linux内核版本的对应关系
  10. eclipse升级后Android使用JAR报错
  11. The Nerd Factor SPOJ - MYQ5
  12. Nginx 安装详细(一)
  13. HashMap 和 Hashtable 的 6 个区别
  14. ubuntu 通过apt安装jdk
  15. Matlab feval函数(转)
  16. oc调javascript方法(evaluateJavaScript:)&&js给oc发通知
  17. java的GUI程序的基本思路是以JFrame为基础
  18. C#高级编程9-第7章 运算符和类型强制转换
  19. 使用yum高速部署Oracle安装环境(11g)
  20. Android踩坑随笔Fragment中onActivityResult方法不被调用

热门文章

  1. 【爬坑系列】之docker的overlay网络配置(未完,待续)
  2. elasticsearch全文搜索
  3. Application,Service,Activity 三者的Context的应用场景
  4. JS 对输入判断变化屏蔽中文输入法连续输入时触发的事件
  5. AFNetworking2.5使用-转
  6. java单元测试注释执行顺序
  7. MySQL+PHP配置 Windows系统IIS版
  8. SpringBoot 2.x (3):文件上传
  9. R in action读书笔记(11)-第八章:回归-- 选择“最佳”的回归模型
  10. iOS---UICollectionView自定义流布局实现瀑布流效果