当我在Windows1064位(32位python)上使用cx_freeze将我的python3.4应用程序编译成一个可执行文件时,我从看似随机的导入尝试(例如导入getpass / import QtCore)中间歇性地得到以下运行时异常(大约是4中的1次):
zipimport.ZipImportError: can't decompress data; zlib not available当我在启动时没有得到错误时,应用程序就可以正常运行。一些注意事项:
1-使用python 2.7构建的类似应用程序没有异常。
2-当我直接从.pyw文件(即解冻)运行时,我不会得到异常。
追踪:
File "c:\python\32-bit\3.4\lib\threading.py", line 921, in _bootstrap_inner
File ".\tempCheckout\CanPy\CanAsync.py", line 400, in run
File ".\tempCheckout\CanPy\CanAsync.py", line 483, in _connect
File "c:\python\32-bit\3.4\lib\importlib\_bootstrap.py", line 2237, in _find_and_load
File "c:\python\32-bit\3.4\lib\importlib\_bootstrap.py", line 2226, in _find_and_load_unlocked
File "c:\python\32-bit\3.4\lib\importlib\_bootstrap.py", line 1191, in _load_unlocked
File "c:\python\32-bit\3.4\lib\importlib\_bootstrap.py", line 1161, in _load_backward_compatible
File ".\tempCheckout\CanPy\CanSsh.py", line 1, in <module>
File "c:\python\32-bit\3.4\lib\importlib\_bootstrap.py", line 2237, in _find_and_load
File "c:\python\32-bit\3.4\lib\importlib\_bootstrap.py", line 2226, in _find_and_load_unlocked
File "c:\python\32-bit\3.4\lib\importlib\_bootstrap.py", line 1191, in _load_unlocked
File "c:\python\32-bit\3.4\lib\importlib\_bootstrap.py", line 1161, in _load_backward_compatible
File ".\tempCheckout\CanPy\CommUtil\SshTunnel.py", line 1, in <module>
File "c:\python\32-bit\3.4\lib\importlib\_bootstrap.py", line 2237, in _find_and_load
File "c:\python\32-bit\3.4\lib\importlib\_bootstrap.py", line 2226, in _find_and_load_unlocked
File "c:\python\32-bit\3.4\lib\importlib\_bootstrap.py", line 1191, in _load_unlocked
File "c:\python\32-bit\3.4\lib\importlib\_bootstrap.py", line 1161, in _load_backward_compatible
zipimport.ZipImportError: can't decompress data; zlib not available而且,我发现这似乎与此相关:freeze "zlib not avaiable" error when using multiple threads
假设我的python3.4应用程序正在使用两个依赖于zlib的外部库,并且它的使用有一个锁。这些库不在python2.7中,因此我没有看到这个问题。如果我能够异步地停止这些库的加载,那么我可能会修复这个问题。
发布于 2016-02-22 17:42:55
好吧,我的假设似乎是正确的。图书馆被装入两个线程中。等待到第一个线程在第二个线程之前导入,似乎已经修复了这个问题。(虽然我可能只是改变了相对的时间,但如果结果是这样的话,我会更新的)。对这些说明的答复如下:
1-python2.7应用程序没有加载zlib,所以这是一个红鲱鱼。
我认为时间安排在.pyw中一定是如此,以至于这个问题没有发生。
https://stackoverflow.com/questions/35556615
复制相似问题