通过py2exe打包python程序的过程中,解决的一系列问题

py2exe的使用方法参考《py2exe使用方法》

注:程序可以在解释器中正常运行,一切问题都出在打包过程中。

问题1:

  • 现象:RuntimeError: maximum recursion depth exceeded in comparison.
  • 原因:Python递归报错。Python中默认的最大递归深度是989,当尝试递归第990时便出现递归深度超限的错误。
  • 解决:在setup.exe中手动设置递归调用深度为10000000,代码如下:
      • import sys
        sys.setrecursionlimit(10000000)

问题2:

  • 现象: import _tkinter ImportError: DLL load failed: %1 不是有效的 Win32 应用程序。 
  • 原因:python解释器版本与tkinter版本不一致。可能是安装了多个python解释器,或者tkinter不是用pip安装、导致其版本与python解释器版本不一致。(本次遇到的情况属于后者)
  • 解决:安装对应版本的python解释器(2.7.10)

问题3:

  • 现象: [Errno 2] No such file or directory: 'libopenblas.IPBC74C7KURV7CB2PKT5Z5FNR3SIBV4J.gfortran-win_amd64.dll' 
  • 解决:在setup.py的setup-options中,dll_excludes下添加 'libopenblas.JKAMQ5EVHIVCPXP2XZJB2RQPIN47S32M.gfortran-win32.dll' ,排除这个dll文件

至此,已经可以打包完成,但打包后的exe无法运行。

问题4:

  • 现象:运行exe时弹出命令行窗口报错,之后在log中发现报错原因: ImportError: No module named mpl_toolkits. 
  • 尝试:中间尝试过在setup.py的setup-options中添加"includes"或"packages"指令,打包时就指定必须导入这个模块。这样的结果就是,打包过程中就出现上述报错,无法完成打包。下文“引申”中的两种方法也尝试过了,都无法解决问题。
  • 解决:仔细查看程序,发现其实不需要用到mpl_toolkits包,于是注释掉mpl_toolkits的导入。
  • 引申:搜索发现这种问题还是比较普遍的,主要的解决方式有两种,以后再出现这个错误时可以尝试这些解决方法(这次的问题这两个方法都无法解决):
    1. 认为原因在于py2exe无法识别运行时的动态导入,解决办法是在文件头就import相关模块(也有人建议,在这个办法的基础上,import部分结束之后,显式地调用一次这个模块,比如xxxx.__version__)
      • 【原地址:https://bytes.com/topic/python/answers/168576-help-py2exe-error-no-module-named-decimal】
    2. 认为原因在于py2exe无法识别egg文件。他的解决办法是: 我发现python的Lib/site-packages下安装的是egg文件,beautifulsoup4-4.4.0-py2.7.egg。用winrar将其解压,把bs4目录直接放到Lib/site-packages下,再打包并执行,一切正常。问题解决。 
      • 【原地址:https://www.cnblogs.com/simplestupid/p/4716658.html】

问题5:

  • 现象:RuntimeError: Could not find the matplotlib data files.
  • 原因:matplotlib运行时缺失一些必要的文件。
  • 解决:在setup.py的setup-options-includes中添加
  • "matplotlib.backends",
    "matplotlib.figure",
    "matplotlib.backends.backend_tkagg"

 

在setup.py的setup中添加

  • data_files = [(r'mpl-data', glob.glob(r'C:\Python27\Lib\site-packages\matplotlib\mpl-data\*.*')),
                  (r'mpl-data', [r'C:\Python27\Lib\site-packages\matplotlib\mpl-data\matplotlibrc']),
                  (r'mpl-data\images', glob.glob(r'C:\Python27\Lib\site-packages\matplotlib\mpl-data\images\*.*')),
                  (r'mpl-data\fonts', glob.glob(r'C:\Python27\Lib\site-packages\matplotlib\mpl-data\fonts\*.*'))]

问题6:

  • 现象:OMP: warning #178:Function GetModuleHandleEx failed:   OMP: System error #126: 找不到模块
  • 解决:在setup.py的setup-options中,取消 "bundle_files":1,不再将所有文件打包到一个exe中。
  • 引申:这个问题出现于用py2exe打包、含numpy包,且把所有文件打包到一个exe中的时候。值得参考的解决方法是: 在setup.py的setup-options中excludes("scipy"和)"numpy",并将它们的整个包文件夹复制到dist目录中,并将该目录添加到python main.py顶部的系统路径中 。
    • 【原地址(关于此报错的一些讨论):https://stackoverflow.com/questions/22412984/omp-warning-when-numpy-1-8-0-is-packaged-with-py2exe】

 附:最终的setup.py

 1 # -*- coding: utf-8 -*-
 2 from distutils.core import setup
 3 import py2exe
 4 import glob
 5 import sys
 6 sys.setrecursionlimit(10000000)
 7 
 8 # 在命令行下运行  python  setup.py  py2exe 
 9 
10 setup(
11     options={
12        "py2exe":{
13             "includes":["sip",
14                         "matplotlib.backends",
15                         "matplotlib.figure",
16                         "matplotlib.backends.backend_tkagg"
17                         ],
18             "dll_excludes":["MSVCP90.dll", 'libopenblas.JKAMQ5EVHIVCPXP2XZJB2RQPIN47S32M.gfortran-win32.dll'],
19             "compressed":1, 
20             "optimize":2, 
21             # "bundle_files":1
22         }
23     },
24     version = "0.1.0", 
25     description = "PID Debug",
26     name = "PID",
27     zipfile=None,
28     data_files = [(r'mpl-data', glob.glob(r'C:\Python27\Lib\site-packages\matplotlib\mpl-data\*.*')),
29                   (r'mpl-data', [r'C:\Python27\Lib\site-packages\matplotlib\mpl-data\matplotlibrc']),
30                   (r'mpl-data\images', glob.glob(r'C:\Python27\Lib\site-packages\matplotlib\mpl-data\images\*.*')),
31                   (r'mpl-data\fonts', glob.glob(r'C:\Python27\Lib\site-packages\matplotlib\mpl-data\fonts\*.*'))],
32     windows=[{"script":'main.py',
33                      "icon_resources":[(1, "3.ico")]
34                     }
35                 ] 
36 )
setup.py

 

posted @ 2019-03-25 19:08  花火·  阅读(3238)  评论(0编辑  收藏  举报