php 导出数据到excel(缓冲区应用)

本文介绍了如何使用PHP结合缓冲区导出数据到Excel,避免内存限制问题。通过开启缓冲区,可以分批输出数据,适用于大量数据导出。在PHP程序中,设置合适的header头,使浏览器识别为附件下载,实现数据的高效导出。
摘要由CSDN通过智能技术生成

昨天写了个php 结合缓冲区读取excel数据并批量导入mysql,缓冲区可有可无,没有多大的影响,接下来介绍一下php导出数据到excel,这次采用缓冲区的方式,大家知道,php中,所有的输出都会用到缓冲区,缓冲区的左右就是协调告诉的cpu与相对缓慢的I/O操作。

echo 'hello123';
sleep(10);
echo '再一次输出hello123';
按照正常的逻辑,程序的运行应该是先输出hello123.之后10秒之后再输出‘再一次输出hello123’;

why?为什么会出现这种问题呢,答案网上一堆,我就简单点说,原因是,php把输出都缓冲了,并且一直到程序执行完才全部输出出来,这样的结果,我可以调处n多的不足:

一,很多时候需要在输出时设置header头,比如我们写程序测试时,输出出来的东西应该是对我们友好可读的,这个时候就需要设置utf8等header头,平时我们都把header头写在程序的开头,这是因为header之前不允许出现echo 等操作,不过这个可以通过php缓冲区避免,比如在第一次echo 之间 开启ob_start(),这样就会正常显示了(但是坚决不推崇这种方法,这是严重浪费系统资源的行为)

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值