Pyinstaller 用于将 Python 应用和连同其所需依赖打包在一起,使其可以在不安装 Python 解释器的相同操作系统的计算机上运行。Pyinstaller 库支持 Python 3.8 及其更新版本,可以正确地打包较大 Python 包 ,如 numpy, matplotlib, PyQt, wxPython 等等。需要注意, Pyinstaller 不是一个跨平台的工具,也就是说,在 Windows 系统打的包只能运行在 Windows 系统上。
安装
# 安装 pyinstaller pip install pyinstaller # 更新到最新版本的 pyinstaller pip install -U pyinstaller # 采用国内阿里 pypi 镜像安装加速 pip install pyinstaller -i https://mirrors.aliyun.com/pypi/simple/
使用
使用命令行选项打包
通过命令行选项输入相关参数,具体命令如下:
pyinstaller -F -w main.py -n 测试工具
其中,
-F 选项,创建一个打包的执行文件;-w 选项,执行文件运行过程中,不出现命令行窗口;-n 测试工具,指定输出的可执行文件名为 "测试工具"。更多选项,参见 Using Pyinstaller - Options 。
使用配置文件打包
pyinstaller 测试工具.spec
配置文件 "测试工具.spec" 的具体内容,如下所示
# -*- mode: python ; coding: utf-8 -*- block_cipher = None a = Analysis( ['main.py'], pathex=[], binaries=[], datas=[], hiddenimports=[], hookspath=[], hooksconfig={}, runtime_hooks=[], excludes=[], win_no_prefer_redirects=False, win_private_assemblies=False, cipher=block_cipher, noarchive=False, ) pyz = PYZ(a.pure, a.zipped_data, cipher=block_cipher) exe = EXE( pyz, a.scripts, a.binaries, a.zipfiles, a.datas, [], name='测试工具', debug=False, bootloader_ignore_signals=False, strip=False, upx=True, upx_exclude=[], runtime_tmpdir=None, console=False, disable_windowed_traceback=False, argv_emulation=False, target_arch=None, codesign_identity=None, entitlements_file=None, )
从配置文件中,可以比较明显地看出,对 main.py 文件进行打包,不显示 console 命令行窗口,输出执行文件名为 "测试工具"。
调试
01. 重新带有 console 的可执行文件
如果 Pyinstaller 生成的可执行文件运行过程中,出现闪退问题。通过重新生成带有 console 命令行的可执行文件,具体命令如下:
pyinstaller -F -c main.py -n 测试工具
从上面命令可以看出,只需把 -w 选项替换为 -c 选项,即可。
或者直接修改配置文件,将 console=False 改为 console=True,重新运行如下命令:
pyinstaller 测试工具.spec
02. 命令行界面运行可执行文件(不要直接双击运行)
为了避免闪退时,命令行界面同时闪退,需要在命令行(Windows cmd 或 Linux shell)下运行 Pyinstaller 生成的可执行文件。
问题及解决方法
问题1,
Python 代码直接运行无问题,而 Pyinstaller 打包生成的可执行文件运行时,出现 ModuleNotFoundError: No module named XXXXXX 问题。
解决方法,
问题原因是,依赖包动态导入其他 Python 库。此时,需要把 XXXXXX 库,添加到配置文件的 hiddenimports=[] 的列表,修改为 hiddenimports=['XXXXXX'] ,其中 XXXXXX 为没有找到的模块名,注意,模块名需要放到引号内。
参考资料
[1] PyInstaller Manual. https://pyinstaller.org/en/stable/.
[2] 2个技巧,学会Pyinstaller打包的高级用法. https://zhuanlan.zhihu.com/p/398619997
标签:可执行文件,pyinstaller,Pyinstaller,笔记,命令行,使用,测试工具,False From: https://www.cnblogs.com/klchang/p/17737586.html