python程序打包成可执行文件【进阶篇】
python程序打包成可执行文件【进阶篇】
提示:博主取舍了很多大佬的博文并亲测有效,分享笔记邀大家共同学习讨论
文章目录
- python程序打包成可执行文件【进阶篇】
-
- @[TOC](文章目录)
- 前言
- 安装PyInstaller包
- 打包深度学习模型
-
- 生成spec文件
- 修改spec文件
- 运行spec文件进行打包
- 执行exe可执行文件
- 总结
- 附录
文章目录
- python程序打包成可执行文件【进阶篇】
-
- @[TOC](文章目录)
- 前言
- 安装PyInstaller包
- 打包深度学习模型
-
- 生成spec文件
- 修改spec文件
- 运行spec文件进行打包
- 执行exe可执行文件
- 总结
- 附录
前言
在【入门篇】中,我们简单介绍了单个py文件如何打包成exe可执行文件直接运行程序。现在我们来更深入的学习python项目打包,如何打包深度学习模型代码。
安装PyInstaller包
在入门篇中已经详细讲述过了,这里只做大致介绍。创建一个纯净的、没有多余的第三方库和模块的小型Python环境,尽可能的少的库和模块要来打包exe可执行文件。
# environment_name 环境名、3.x Python的版本
conda create -n environment_name python==3.x
# 激活新环境
source activate environment_name
# 下载安装Pyinstaller模块
pip install -i https://pypi.tuna.tsinghua.edu.cn/simple Pyinstaller
打包深度学习模型
博主以MiVOS官方Pytorch代码简约版为例:
不需要事先MiVOS模型原理和代码,这里只是为了方便讲解
生成spec文件
深度学习模型的项目文件一般比较复杂,文件之间的引用会比较多,因此更加适合使用spec文件对整个项目进行的打包,执行以下命令生成spec文件:
# xxx.py 一般是需要执行的主文件,深度学习模型中一般为推理文件
pyi-makespec -w xxx.py
# eg: pyi-makespec -w interactive_gui_4.1.py
修改spec文件
由于打包的主文件是xxx.py,因此生成的spec文件名称为xxx.spec,俩者在同一个文件夹下:
默认生成的spec文件初始内容如下所示:
# -*- mode: python ; coding: utf-8 -*-block_cipher = Nonea = Analysis(['interactive_gui_4.1.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,[],exclude_binaries=True,name='interactive_gui_4.1',debug=False,bootloader_ignore_signals=False,strip=False,upx=True,console=False,disable_windowed_traceback=False,argv_emulation=False,target_arch=None,codesign_identity=None,entitlements_file=None,
)
coll = COLLECT(exe,a.binaries,a.zipfiles,a.datas,strip=False,upx=True,upx_exclude=[],name='interactive_gui_4.1',
)
更改几个位置内容:
名称 | 作用 |
---|---|
Analysis的第一个[] | 声明打包文件(xxx.py)引用到的py文件夹路径 |
pathex | 打包的模型文件夹路径 |
binaries | 权重文件pth路径 (以元组的形式) |
datas | 非py文件(包括但不限于图片数据集)的路径(以元组的形式) |
只展示更改位置的内容
['interactive_gui_4.1.py',"E:/deep-learning-for-image-processing-master/MiVOS/inference_core.py","E:/deep-learning-for-image-processing-master/MiVOS/model/s2m/_deeplab.py","E:/deep-learning-for-image-processing-master/MiVOS/model/s2m/s2m_network.py","E:/deep-learning-for-image-processing-master/MiVOS/model/s2m/s2m_resnet.py","E:/deep-learning-for-image-processing-master/MiVOS/model/s2m/utils.py","E:/deep-learning-for-image-processing-master/MiVOS/model/propagation/mod_resnet.py","E:/deep-learning-for-image-processing-master/MiVOS/model/propagation/modules.py","E:/deep-learning-for-image-processing-master/MiVOS/model/propagation/prop_net.py","E:/deep-learning-for-image-processing-master/MiVOS/model/aggregate.py","E:/deep-learning-for-image-processing-master/MiVOS/model/attn_network.py","E:/deep-learning-for-image-processing-master/MiVOS/model/fusion_model.py","E:/deep-learning-for-image-processing-master/MiVOS/model/fusion_net.py","E:/deep-learning-for-image-processing-master/MiVOS/interact/interaction.py","E:/deep-learning-for-image-processing-master/MiVOS/interact/s2m_controller.py",],pathex=["E:/deep-learning-for-image-processing-master/MiVOS"],binaries=[("E:/deep-learning-for-image-processing-master/MiVOS/saves/s2m.pth", "saves"),("E:/deep-learning-for-image-processing-master/MiVOS/saves/fusion.pth", "saves"),("E:/deep-learning-for-image-processing-master/MiVOS/saves/propagation_model.pth", "saves")],datas=[],
这里datas是空的是因为interactive_gui_4.1.py代码中可以通过以下命令指定数据集的存放位置:
parser.add_argument('--images', help='Folder containing input images. Either this or --video needs to be specified.')
当然binaries也可以是空的,不过在推理阶段,通常权重文件已经确定,因此放置位置是固定的,元组的形式为(“权重文件pth绝对路径”, “拷贝权重文件pth到打包模型文件内的指定文件夹下”)。
运行spec文件进行打包
修改spec文件后,在激活的对应虚拟环境下进行打包用如下命令进行打包,否者会报错:
pyinstaller xxx.spec
# eg: pyinstaller interactive_gui_4.1.spec
完成打包后在pathex指定的模型工程文件夹下产生build(可以删除)和dist文件夹:
所需的可执行文件在dist目录内:
成功拷贝权重文件pth到打包模型文件内的指定文件夹下:
通常数据集地址是根据使用者而定的,没必要拷贝到打包模型文件内的指定文件夹下固定死。
执行exe可执行文件
通常可以直接点击exe运行项目,因为不需要用命令行进行额外的输入。博主打包的exe需要命令行进行外部输入,因此用cmd命令行执行:
# 在exe所在的目录下执行命令
interactive_gui_4.1.exe --images E:\\deep-learning-for-image-processing-master\\MiVOS\\testimages
总结
与其他的打包模块相比,使用Python的Pyinstaller模块进行打包的使用者最多,用起来简便,因此本文以Pyinstaller模块打包Python深度学习模型为例,为大家提供一个进阶参考。
附录
博主打包的exe是交互式视频分割的工具,电脑性能不错的朋友,想体验的大伙可以从【MiVOS的exe百度云地址,提取码:bele】获取,无需安装环境就可以体验。【官方实现效果参考】,博主做了部分功能简化,只保留了核心功能,想了解MiVOS原理和代码的请参考博主的【MiVOS官方Pytorch代码讲解系列】。