php 大数据导出CSV的问题

发布于 2022-09-03 11:26:40 字数 147 浏览 12 评论 0

我现用php导出csv 实现过程是先生成文件,然后然后分批次查询数据然后foreach 循环在一条一条写入文件,写入完成后执行下载方法下载文件,我现在的问题如果数据多的话,php程序执行完了,看文件还是一直在写入,不能执行下载方法,所以文件就下载不了,请问有什么办法解决这个问题?

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(4

我要还你自由 2022-09-10 11:26:40

这种数据量,单个php请求一般是会超时的。

建议php文件每次请求只处理10条数据,追加写入csv文件,单次请求快速返回。

然后写一个js程序,ajax循环调用这个php文件,直到数据都处理完了,触发网页下载动作。这样做还有一个好处,前端网页可以实时显示处理进度。

天赋异禀 2022-09-10 11:26:40

因为csv本质是纯文本,你可以配合js和php,js发起多个请求分批过去字符串,最后让js合并生成文件(链接以data:的方式)

旧时浪漫 2022-09-10 11:26:40

文件未完全生成,按钮是disable状态

吃素的狼 2022-09-10 11:26:40

点击【导出】按钮,提示csv文件正在生成,你可以离开整个页面,稍后回来看生成进度。

然后后端异步脚本去生成这个CSV

前端刷新/AJAX请求检测这个CSV生成状态,如果可以了 给一个下载按钮

个人认为这种体验较好,仅供参考

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文