每次写完程序我都在想,难道自己的程序只能在pycharm上运行吗,就想java写的web程序可以部署到tomcat上一样,我是否可以将python打包成exe。
然后我找到了一个pycharm支持的第三方包pyinstaller可以用于对py文件进行打包。
经过尝试,我成功将我的学生系统打包出来
下面分享一下打包过程:
首先,检查自己的python版本,因为现在pyinstaller只支持python2.x和python3.6.x及以下,如果你是python3.7.0请等待pyinstaller进化或者安装老版本的pythone
-
python版本检查完后,为了使我们的python有包可用,打开cmd使用下面两种命令之一:
1.python -m pip install pyinstaller
2.python -m pip --upgrade pyinstaller
等到命令执行完成后,检查你python放置的文件夹的site-packages是否有了pyinstaller和pinwin32的相关包
-
打开pycharm,找到你要打包的py文件(工程文件),然后file -> setting -> project:xxxxx -> project interpreter -> 点击右侧+号 -> 搜索框内输入pyinstaller-> 选择pyinstaller点击下方的Install package -> 等待下方显示绿色横条才算成功(红色导入失败?不存在的,忘了我们第2步做的什么吗,事实上pyinstaller早就在我们手里捏着了)
-
这些工作都搞定,现在前往你的python工程的程序入口,就是程序最开始执行的py文件处(其实无所谓但是方便我们看谁是入口)比如我就是__init__.py作为程序入口。点击最下方的Terminal
-
在Terminal中输入我们的最后一条命令:
pyinstaller -F(必须大写) -w(使用自己编写的窗口运行写上,本就是控制台运行的程序不要写) 入口py文件
比如我的程序就输入:
pyinstaller -F __init__.py
等待命令执行完毕,最后一条消息显示success表明我们的exe文件生成成功了
进入工程文件夹查看,会多出以下文件
其中dist中存放生成的exe文件,注意,要完整运行exe文件,需要把程序中非py的资源文件(文本,图片,音频)按照原来的存放方式和exe文件放在同一目录下,例如我的程序
现在点击这个exe就能运行了!!!!!!!!
注:当然pyinstaller的配置参数还有很多,请各位自己去发掘,下附参数列表
通用参数
参数名 | 描述 | 说明 |
---|---|---|
-h | 显示帮助 | 无 |
-v | 显示版本号 | 无 |
–distpath | 生成文件放在哪里 | 默认:当前目录的dist文件夹内 |
–workpath | 生成过程中的中间文件放在哪里 | 默认:当前目录的build文件夹内 |
-y | 如果dist文件夹内已经存在生成文件,则不询问用户,直接覆盖 | 默认:询问是否覆盖 |
–upx-dir UPX_DIR | 指定upx工具的目录 | 默认:execution path |
-a | 不包含unicode支持 | 默认:尽可能支持unicode |
–clean | 在本次编译开始时,清空上一次编译生成的各种文件 | 默认:不清除 |
–log-level LEVEL | 控制编译时pyi打印的信息 | 一共有5个等级,由低到高分别为TRACE DEBUG INFO(默认) WARN ERROR CRITICAL。也就是默认清空下,不打印TRACE和DEBUG信息 |
与生成结果有关的参数
参数名 | 描述 | 说明 |
---|---|---|
-D | 生成one-folder的程序(默认) | 生成结果是一个目录,各种第三方依赖、资源和exe同时存储在该目录 |
-F | 生成one-file的程序 | 生成结果是一个exe文件,所有的第三方依赖、资源和代码均被打包进该exe内 |
–specpath | 指定.spec文件的存储路径 | 默认:当前目录 |
-n | 生成的.exe文件和.spec的文件名 | 默认:用户脚本的名称,即main.py和main.spec |
指定打包哪些资源、代码
参数名 | 描述 | 说明 |
---|---|---|
–add-data | 打包额外资源 | 用法:pyinstaller main.py –add-data=src;dest。windows以;分割,linux以:分割 |
–add-binary | 打包额外的代码 | 用法:同–add-data。与–add-data不同的是,用binary添加的文件,pyi会分析它引用的文件并把它们一同添加进来 |
-p | 指定额外的import路径,类似于使用PYTHONPATH | 参见PYTHONPATH |
–hidden-import | 打包额外py库 | pyi在分析过程中,有些import没有正确分析出来,运行时会报import error,这时可以使用该参数 |
–additional-hooks-dir | 指定用户的hook目录 | hook用法参见其他,系统hook在PyInstaller\hooks目录下 |
–runtime-hook | 指定用户runtime-hook | 如果设置了此参数,则runtime-hook会在运行main.py之前被运行 |
–exclude-module | 需要排除的module | pyi会分析出很多相互关联的库,但是某些库对用户来说是没用的,可以用这个参数排除这些库,有助于减少生成文件的大小 |
–key | pyi会存储字节码,指定加密字节码的key | 16位的字符串 |
生成参数
参数名 | 描述 | 说明 |
---|---|---|
-d | 执行生成的main.exe时,会输出pyi的一些log,有助于查错 | 默认:不输出pyi的log |
-s | 优化符号表 | 原文明确表示不建议在windows上使用 |
–noupx | 强制不使用upx | 默认:尽可能使用。 |
其他
参数名 | 描述 | 说明 |
---|---|---|
–runtime-tmpdir | 指定运行时的临时目录 | 默认:使用系统临时目录 |
Windows和Mac特有的参数
参数名 | 描述 | 说明 |
---|---|---|
-c | 显示命令行窗口 | 与-w相反,默认含有此参数 |
-w | 不显示命令行窗口 | 编写GUI程序时使用此参数有用。 |
-i | 为main.exe指定图标 | pyinstaller -i beauty.ico main.py |
Windows特有的参数
参数名 | 描述 | 说明 |
---|---|---|
–version-file | 添加版本信息文件 | pyinstaller –version-file ver.txt |
-m, –manifest | 添加manifest文件 | pyinstaller -m main.manifest |
-r RESOURCE | 请参考原文 | |
–uac-admin | 请参考原文 | |
–uac-uiaccess | 请参考原文 |