我现用php导出csv 实现过程是先生成文件,然后然后分批次查询数据然后foreach 循环在一条一条写入文件,写入完成后执行下载方法下载文件,我现在的问题如果数据多的话,php程序执行完了,看文件还是一直在写入,不能执行下载方法,所以文件就下载不了,请问有什么办法解决这个问题?
我现用php导出csv 实现过程是先生成文件,然后然后分批次查询数据然后foreach 循环在一条一条写入文件,写入完成后执行下载方法下载文件,我现在的问题如果数据多的话,php程序执行完了,看文件还是一直在写入,不能执行下载方法,所以文件就下载不了,请问有什么办法解决这个问题?
点击【导出】按钮,提示csv文件正在生成,你可以离开整个页面,稍后回来看生成进度。
然后后端异步脚本去生成这个CSV
前端刷新/AJAX请求检测这个CSV生成状态,如果可以了 给一个下载按钮
个人认为这种体验较好,仅供参考
1 回答4k 阅读✓ 已解决
3 回答1.8k 阅读✓ 已解决
2 回答2.2k 阅读✓ 已解决
1 回答1.4k 阅读✓ 已解决
2 回答2.2k 阅读
1 回答567 阅读✓ 已解决
784 阅读
这种数据量,单个php请求一般是会超时的。
建议php文件每次请求只处理10条数据,追加写入csv文件,单次请求快速返回。
然后写一个js程序,ajax循环调用这个php文件,直到数据都处理完了,触发网页下载动作。这样做还有一个好处,前端网页可以实时显示处理进度。