打开APP
userphoto
未登录

开通VIP,畅享免费电子书等14项超值服

开通VIP
web.py 大文件下载

需要下载大文件的时候,如果先将文件直接读入内容再返回,那肯定就很浪费内存,甚至会崩溃。

所以我们需要读一些内容然后直接flush给客户端,但是web.py的文档里面却没有找到flush的方法。

不过在web.py的cookbook中的How to Stream Large Files中看到可以直接yield返回内容。所以,我们可以使用yield来做flush做的事情。

BUF_SIZE = 262144
class download:
    def GET(self):
        file_name = 'file_name'
        file_path = os.path.join('file_path', file_name)
        f = None
        try:
            f = open(file_path, "rb")
            webpy.header('Content-Type','application/octet-stream')
            webpy.header('Content-disposition', 'attachment; filename=%s.dat' % file_name)
            while True:
                c = f.read(BUF_SIZE)
                if c:
                    yield c
                else:
                    break
        except Exception, e:
            print e
            yield 'Error'
        finally:
            if f:
                f.close()
 

OK!
完鸟!

本站仅提供存储服务,所有内容均由用户发布,如发现有害或侵权内容,请点击举报
打开APP,阅读全文并永久保存 查看更多类似文章
猜你喜欢
类似文章
【热】打开小程序,算一算2024你的财运
python文件对比利用difflib库实现文件夹下详细内容对比
如何构建一个简单的基于命令行的python项目
Office 文件转 PDF 之服务实战
Python自动打开文件夹,并定位到指定文件或打开指定文件之os模块
ueditor 在springboot 打jar运行时 找不到图片附件路径问题
python gz文件解压
更多类似文章 >>
生活服务
热点新闻
分享 收藏 导长图 关注 下载文章
绑定账号成功
后续可登录账号畅享VIP特权!
如果VIP功能使用有故障,
可点击这里联系客服!

联系客服