Python zipfile.ZipFile 压缩损坏的文件
我有一个 Django 视图,用户可以调用它来调用本地服务器上的 zip 文件。它使用 zipfile.ZipFile 将多个文件压缩为一个 zip,如下所示:
with ZipFile(my_dir + 'folder.zip', 'w') as zipObj:
zipObj.write(my_dir + '1.json')
zipObj.write(my_dir + '2.json')
然后我将此文件返回给用户作为响应:
folder_file = open(full_path, "r", encoding='Cp437')
response = HttpResponse(FileWrapper(folder_file), content_type='application/zip')
但是下载的文件已损坏,我无法使用 ubuntu archive 打开它经理。
然后,当我尝试在 django 服务器中使用具有相同包的 python 解压缩文件时,我仍然收到错误:
with ZipFile(file_path, 'r') as zip_ref:
zip_ref.extractall(my_dir)
我收到的错误是:
File ".../views.py", line 38, in post
with ZipFile(file_path, 'r') as zip_ref:
File "/usr/lib/python3.8/zipfile.py", line 1269, in __init__
self._RealGetContents()
File "/usr/lib/python3.8/zipfile.py", line 1354, in _RealGetContents
fp.seek(self.start_dir, 0)
OSError: [Errno 22] Invalid argument
知道我在这里做错了什么吗?
I have a Django view which users can call to zip files at my local server. It uses zipfile.ZipFile
to compresses multiple files into a single zip as follows:
with ZipFile(my_dir + 'folder.zip', 'w') as zipObj:
zipObj.write(my_dir + '1.json')
zipObj.write(my_dir + '2.json')
Then I return this file to the user in response:
folder_file = open(full_path, "r", encoding='Cp437')
response = HttpResponse(FileWrapper(folder_file), content_type='application/zip')
But the downloaded file is corrupt, I can't open it using ubuntu archive manager.
Then when i try to unzip the file using python with the same package in my django server, I still get the error:
with ZipFile(file_path, 'r') as zip_ref:
zip_ref.extractall(my_dir)
The error I get is:
File ".../views.py", line 38, in post
with ZipFile(file_path, 'r') as zip_ref:
File "/usr/lib/python3.8/zipfile.py", line 1269, in __init__
self._RealGetContents()
File "/usr/lib/python3.8/zipfile.py", line 1354, in _RealGetContents
fp.seek(self.start_dir, 0)
OSError: [Errno 22] Invalid argument
Any idea what am I doing wrong here?
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
data:image/s3,"s3://crabby-images/d5906/d59060df4059a6cc364216c4d63ceec29ef7fe66" alt="扫码二维码加入Web技术交流群"
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(3)
这应该是一个评论,但我认为它太长了。
我认为你应该看看你的路径,因为错误的路径可能会导致不必要的行为。从 zipfile 写入:
以及来自zipfile extractc(全部):
因此请确保 Shure 使用正确的路径。并确保 Shure 中没有有问题的字符(例如通配符 )或反斜杠)像这里
也许你应该用其他(un -) zip Tootls 看看是否有区别,有时它们更具体(像这里)
This should be a comment, but i think it's to long.
I think you should have a look at your paths, because wrong path can lead to unwanted behaviour. From the zipfile write:
and from zipfile extratc (all):
So make shure you use a correct path. And make shure they do not have problematic characters (like wildcards or backslashes) like here
Maybe you should test with other (un-) zip tootls to see if it makes a difference, Sometimes they are more concrete (Like here)
您可以尝试这样的事情。
you can try something like this.
创建httpresponse时,以二进制模式打开zip文件,以避免newline转换的错误:
Open the zip file in binary mode when creating the HttpResponse to avoid errors whith newline conversion: