php 大数据导出CSV的问题
程序员文章站
2022-05-10 17:41:40
...
我现用php导出csv 实现过程是先生成文件,然后然后分批次查询数据然后foreach 循环在一条一条写入文件,写入完成后执行下载方法下载文件,我现在的问题如果数据多的话,php程序执行完了,看文件还是一直在写入,不能执行下载方法,所以文件就下载不了,请问有什么办法解决这个问题?
回复内容:
我现用php导出csv 实现过程是先生成文件,然后然后分批次查询数据然后foreach 循环在一条一条写入文件,写入完成后执行下载方法下载文件,我现在的问题如果数据多的话,php程序执行完了,看文件还是一直在写入,不能执行下载方法,所以文件就下载不了,请问有什么办法解决这个问题?
这种数据量,单个php请求一般是会超时的。
建议php文件每次请求只处理10条数据,追加写入csv文件,单次请求快速返回。
然后写一个js程序,ajax循环调用这个php文件,直到数据都处理完了,触发网页下载动作。这样做还有一个好处,前端网页可以实时显示处理进度。
因为csv本质是纯文本,你可以配合js和php,js发起多个请求分批过去字符串,最后让js合并生成文件(链接以data:的方式)
文件未完全生成,按钮是disable状态
上一篇: PHP7多线程搭建教程
推荐阅读
-
详解mysqldump数据导出的问题
-
PHP怎么在导出csv的时候加双引号
-
使用PHP导出Redis数据到另一个Redis中的代码_PHP
-
老话题了.PHP导出EXCEL,phpexcel类很强大,但是效率低速度慢,fputcsv速度快但不知道怎么解决科学计数法的问题,求老司机传授经验
-
【手机上传】jQuery传递数据同时上传文件到php后台接受不到的问题
-
昨天写支付接口时遇到支付接口返回数据接收地址,session数据丢失(或者说失效)的问题,session数据丢失_PHP教程
-
关于php查询数据库记录显示的有关问题
-
php导出csv格式数据并将数字转换成文本的思路以及代码分享_PHP教程
-
怎么用PHP实现数据库导出到txt文件或csv文件
-
php使用指定编码导出mysql数据到csv文件的方法