博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
PHP导出超大的CSV格式的Excel表方案
阅读量:6955 次
发布时间:2019-06-27

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

场景和痛点

说明

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

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

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

编写过程

说明

关键具体在代码里注释

代码

$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

转载地址:http://gztil.baihongyu.com/

你可能感兴趣的文章
如何助力企业 APP 在竞争中占据先机?
查看>>
[译]在 React.js 中使用 ES6+
查看>>
协同过滤算法
查看>>
移动端原生JS实现手指跟随的触控滑动
查看>>
js初级应用之svg实现环形进度条
查看>>
ASP.NET CORE下运行CMD命令
查看>>
requests库核心API源码分析
查看>>
C语言程序员不会告诉你的14个工具和插件 | 收藏 ...
查看>>
2019年人工智能硬件与应用大趋势
查看>>
2018 FDA获批医疗器械盘点,政策红利能否继续?
查看>>
Git协同工作流介绍
查看>>
语音识别实时对比(百度收费 VS SpeechTexter免费)
查看>>
2018智能汽车盘点,新旧造车势力的智能化PK
查看>>
阿里云服务器的配置及搭建教程
查看>>
书籍:python游戏编码 Coding Games in Python - 2018
查看>>
Docker镜像细节
查看>>
如何通过脚本实现数据动态更新
查看>>
远禾科技出席阿里ASRC生态大会 并参与安恒西湖论剑
查看>>
使用eclipse创建web项目的项目图文步骤
查看>>
window powershell 获取所有用户的最后登录时间
查看>>