Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

Function to create in-memory zip file and return as http response

I am avoiding the creation of files on disk, this is what I have got so far:

def get_zip(request):
    import zipfile, StringIO
    i = open('picture.jpg', 'rb').read()
    o = StringIO.StringIO()
    zf = zipfile.ZipFile(o, mode='w')
    zf.writestr('picture.jpg', i)
    zf.close()
    o.seek(0)
    response = HttpResponse(o.read())
    o.close()
    response['Content-Type'] = 'application/octet-stream'
    response['Content-Disposition'] = "attachment; filename=\"picture.zip\""
    return response

Do you think is correct-elegant-pythonic enough? Any better way to do it?

Thanks!

like image 250
nabucosound Avatar asked Mar 09 '10 18:03

nabucosound


2 Answers

For StringIO you should generally use o.getvalue() to get the result. Also, if you want to add a normal file to the zip file, you can use zf.write('picture.jpg'). You don't need to manually read it.

like image 196
Lukáš Lalinský Avatar answered Sep 29 '22 03:09

Lukáš Lalinský


Avoiding disk files can slow your server to a crawl, but it will certainly work.

You'll exhaust memory if you serve too many of these requests concurrently.

like image 42
S.Lott Avatar answered Sep 29 '22 04:09

S.Lott