Python - 压缩文件时出错,'L'格式需要0 <= number <= 4294967295

Aol*_*ola 9 python zip filenames

我运行此代码来压缩文件夹和文件.

def save_folder_as_zip(self, folder_to_zip, save_as):
    zipf = zipfile.ZipFile(str(save_as), mode="w", allowZip64=True)
    self.create_zip(zipf, folder_to_zip)
    zipf.close()

    return zipf

def create_zip(self, zipf, directory, folder=""):

    directory = directory.encode("utf-8")

    for item in os.listdir(directory):
        if temp_folder == directory + os.sep:
            continue

        try:
            if os.path.isfile(os.path.join(directory, item)):
                zipf.write(os.path.join(directory, item), folder + os.sep + item)
            elif os.path.isdir(os.path.join(directory, item)):
                self.create_zip(zipf, os.path.join(directory, item).decode("utf-8"), folder + os.sep + item)
        except Exception, e:
            self.schedule.machine.log_warning(str(e))
Run Code Online (Sandbox Code Playgroud)

但后来我得到了这个错误:

'L' format requires 0 <= number <= 4294967295
Run Code Online (Sandbox Code Playgroud)

发生这种情况的文件名示例:

/[Wii]TrackMania[PAL][WiiSOS.com]/ws_tramap.iso
Run Code Online (Sandbox Code Playgroud)

我有什么想法可以解决这个问题?

追溯:

Traceback (most recent call last):
File "test.py", line 29, in <module>
   save_folder_as_zip("/Users/f/Downloads/", "hei.zip")
File "test.py", line 13, in save_folder_as_zip
   create_zip(zipf, folder_to_zip)
File "test.py", line 26, in create_zip
   create_zip(zipf, os.path.join(directory, item).decode("utf-8"), folder + os.sep + item)  
File "test.py", line 24, in create_zip
   zipf.write(os.path.join(directory, item), folder + os.sep + item)
File "/System/Library/Frameworks/Python.framework/Versions/2.7/lib/python2.7/zipfile.py", line 1100, in write
   zinfo.file_size))
struct.error: 'L' format requires 0 <= number <= 4294967295
Run Code Online (Sandbox Code Playgroud)

enl*_*vin 2

我认为可以通过应用此错误报告附带的补丁来修复此问题:

http://bugs.python.org/issue9720

当您尝试包含在 zip 文件中的文件的原始或压缩形式大于 2^32-1 字节时,就会出现问题。在这种情况下,库需要存储 -1 作为文件大小/压缩大小,并且必须分配一些额外的字段来存储实际大小,这不适合 32 位双字。

由于某种原因,该补丁在 3.2 或 2.7.2+ 中尚未被接受,但我已经对其进行了测试,并且工作正常。我认为它不能用 writestr() 方法修复一些极端情况,但如果你只使用 write() 来存储文件,它会很好用。