python程序打包成可执行文件【进阶篇】

python程序打包成可执行文件【进阶篇】

提示:博主取舍了很多大佬的博文并亲测有效,分享笔记邀大家共同学习讨论


文章目录

  • 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代码简约版为例:
python程序打包成可执行文件【进阶篇】_第1张图片

不需要事先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 = None


a = 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',
)

更改几个位置内容:
python程序打包成可执行文件【进阶篇】_第2张图片

名称 作用
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文件夹:
python程序打包成可执行文件【进阶篇】_第3张图片
所需的可执行文件在dist目录内:
python程序打包成可执行文件【进阶篇】_第4张图片
成功拷贝权重文件pth到打包模型文件内的指定文件夹下:
python程序打包成可执行文件【进阶篇】_第5张图片
通常数据集地址是根据使用者而定的,没必要拷贝到打包模型文件内的指定文件夹下固定死。

执行exe可执行文件

通常可以直接点击exe运行项目,因为不需要用命令行进行额外的输入。博主打包的exe需要命令行进行外部输入,因此用cmd命令行执行:

# 在exe所在的目录下执行命令
interactive_gui_4.1.exe --images E:\deep-learning-for-image-processing-master\MiVOS\testimages

python程序打包成可执行文件【进阶篇】_第6张图片
python程序打包成可执行文件【进阶篇】_第7张图片


总结

与其他的打包模块相比,使用Python的Pyinstaller模块进行打包的使用者最多,用起来简便,因此本文以Pyinstaller模块打包Python深度学习模型为例,为大家提供一个进阶参考。


附录

博主打包的exe是交互式视频分割的工具,电脑性能不错的朋友,想体验的大伙可以从【MiVOS的exe百度云地址,提取码:bele】获取,无需安装环境就可以体验。【官方实现效果参考】,博主做了部分功能简化,只保留了核心功能,想了解MiVOS原理和代码的请参考博主的【MiVOS官方Pytorch代码讲解系列】。
python程序打包成可执行文件【进阶篇】_第8张图片

你可能感兴趣的:(python程序打包,python)