首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >在Django中使用Python ZipStream获取腐败的zip

在Django中使用Python ZipStream获取腐败的zip
EN

Stack Overflow用户
提问于 2014-10-15 17:18:13
回答 1查看 1.4K关注 0票数 4

我对Django有点陌生,所以请容忍我。

我使用来自这里的zip流,并有一个Django视图,该视图返回所有文件附件的压缩文件,这些附件都托管在S3上。但是当我下载的时候,压缩文件都被破坏了,也就是说,我不能打开它们。我试过用unzip -t验证这些文件,但是错误并不是很有帮助。

代码语言:javascript
复制
file_paths = [fa.file.url for fa in file_attachments.all()]

zf = zipstream.ZipFile(mode='w', compression=zipstream.ZIP_DEFLATED)

zip_subdir = "Attachments-%s" % (request_id)

for file_path in file_paths:
    file_dir, file_name = os.path.split(file_path)

    zf.writestr(file_name, urllib.urlopen(file_path).read())

zip_filename = "%s.zip" % (zip_subdir)

response = StreamingHttpResponse(zf, mimetype='application/zip')
response['Content-Disposition'] = \
    'attachment; filename={}'.format(zip_filename)
return response

有什么想法吗?

解决了。

代码语言:javascript
复制
s = StringIO.StringIO()
with zipstream.ZipFile(s, mode='w', compression=zipstream.ZIP_DEFLATED) as zf:
    #could fail on url open.
    for file_path in file_paths:
        file_dir, file_name = os.path.split(file_path)

        try:
            file_contents = urllib.urlopen(file_path).read()
            zf.writestr(file_name, file_contents)
        except IOError: #connection cannot be made
            logging.error()

response = StreamingHttpResponse(s.getvalue(), mimetype='application/octet-stream')
response['Content-Disposition'] = \
    'attachment; filename={}'.format("%s" % (request_id))
return response
EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2014-10-15 17:23:37

当您写完ZipFile时,应该关闭它。否则,引用文档的话,“基本记录将不会被写入”,直到你这样做。

最干净的方法是使用with语句:

代码语言:javascript
复制
with zipstream.ZipFile(mode='w', compression=zipstream.ZIP_DEFLATED) as zf:
    # ...write to zf...
票数 3
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/26388324

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档