掌握PyInstaller:从基础到进阶的Python应用打包指南

无妄无望 2025-03-19 11:23:13编程技术
588

在当今快速发展的软件开发领域,Python凭借其简洁易读、功能强大的特点,成为了众多开发者的首选编程语言。然而,Python脚本的分发与部署一直是一个挑战,尤其是在需要将脚本转换为独立可执行文件时。PyInstaller,作为一款高效的Python应用打包工具,应运而生,它能够帮助开发者轻松地将Python脚本打包为无需依赖Python环境的独立可执行文件。本文将从PyInstaller的基础用法出发,逐步深入到高级功能,通过实例演示和详细解析,带你全面掌握这一强大的打包工具,让你的Python应用分发与部署更加便捷、高效。

1、PyInstaller是什么

PyInstaller 是一个用于将 Python 脚本打包成独立可执行文件的工具。它支持跨平台打包,可以在 Windows、macOS 和 Linux 系统上使用。PyInstaller 会自动处理脚本的依赖项,并将它们打包到一个可执行文件或一个包含所有文件的目录中。

功能特点

  • 跨平台支持:可以在 Windows、macOS 和 Linux 系统上使用。

  • 自动处理依赖项:自动分析脚本的依赖项,并将它们打包到可执行文件中。

  • 生成单个可执行文件:可以将所有依赖项打包到一个单独的可执行文件中,方便分发。

  • 支持多种打包选项:可以指定窗口化应用、隐藏控制台窗口等选项。

2.PyInstaller怎么用 

2.1基本用法

1. 生成可执行文件:

在终端或命令提示符中导航到包含 Python 脚本的目录,然后运行以下命令:

pyinstaller script_name.py

这将生成一个 `dist` 目录,其中包含可执行文件。

2. 生成单个可执行文件:

如果想将所有依赖项打包到一个单独的可执行文件中,可以使用 `-F` 或 `--onefile` 选项:

pyinstaller -F script_name.py

3. 指定输出目录:

如果想指定输出目录,可以使用 `-o` 或 `--distpath` 选项:

 pyinstaller -F -o output_directory script_name.py

4. 隐藏控制台窗口:

如果打包的是 GUI 应用程序,并且不想显示控制台窗口,可以使用 `-w` 或 `--windowed` 选项:

pyinstaller -F -w script_name.py

2.2高级选项

- 添加图标:可以使用 `--icon` 选项为可执行文件添加图标:

pyinstaller -F --icon=icon.ico script_name.py

- 指定临时文件目录:可以使用 `--workpath` 选项指定临时文件目录:

pyinstaller -F --workpath=build_directory script_name.py

- 排除不需要的模块:可以使用 `--exclude-module` 选项排除不需要的模块:

pyinstaller -F --exclude-module=module_name script_name.py

3、PyInstaller使用示例

3.1 单个文件打包

(1)打包命令:

在终端,main.py文件所在文件夹和环境

pyinstaller -F main.py

打包成功

掌握PyInstaller:从基础到进阶的Python应用打包指南

(2)修改main.spec配置文件

中括号中是你的py文件,pathex中是你文件躲在的绝对路径

掌握PyInstaller:从基础到进阶的Python应用打包指南

(3)执行main.spec配置文件

pyinstaller main.spec

 3.2 多个文件的示例

(1)与单个文件相同

(2)修改spec配置文件

① 所有需要的py文件和绝对路径

掌握PyInstaller:从基础到进阶的Python应用打包指南

②  所有资源存在data  
data是一个列表,数据存放以二元组形式存放,前面的是数据名称,后面的是相对于predict_tinajin.py当前目录的路径。  

③  最好在exe文件所在目录打开终端运行exe文件,这样即使报错也不会一闪而过。一般是报错或者exe执行完终端界面就会消失,在所在路径的地方运行就不会

4、关于spec更详细的信息

当然,以下是对 .spec 文件中给出的 PyInstaller 配置的逐行解释:

a = Analysis(
    ['predict_tianjin.py'],  # 1
    pathex=[],               # 2
    binaries=[],             # 3
    datas=[],                # 4
    hiddenimports=[],        # 5
    hookspath=[],            # 6
    hooksconfig={},          # 7
    runtime_hooks=[],        # 8
    excludes=[],             # 9
    noarchive=False,         # 10
    optimize=0,              # 11
)
pyz = PYZ(a.pure)  # 12
exe = EXE(
    pyz,                     # 13
    a.scripts,               # 14
    a.binaries,              # 15
    a.datas,                 # 16
    [],                      # 17
    name='predict_tianjin',  # 18
    debug=False,             # 19
    bootloader_ignore_signals=False,  # 20
    strip=False,             # 21
    upx=True,                # 22
    upx_exclude=[],          # 23
    runtime_tmpdir=None,     # 24
    console=True,            # 25
    disable_windowed_traceback=False,  # 26
    argv_emulation=False,    # 27
    target_arch=None,        # 28
    codesign_identity=None,  # 29
    entitlements_file=None,  # 30
)

解释:

['predict_tianjin.py']: 这是主脚本文件的路径列表,PyInstaller 将从这个脚本开始分析依赖项。

pathex=[]: 这是额外的路径列表,PyInstaller 将在此列表中的路径中搜索模块。

binaries=[]: 这是包含非 Python 二进制文件的元组列表,格式为 (src, dest),其中 src 是打包文件的路径,dest 是打包文件在可执行文件中的路径。

datas=[]: 这是包含数据文件的元组列表,格式与 binaries 相同。

hiddenimports=[]: 这是需要隐式导入的模块列表,这些模块可能没有在脚本中直接导入,但需要包含在打包中。

hookspath=[]: 这是包含 PyInstaller 钩子文件的路径列表,这些钩子文件用于处理特定模块的打包需求。

hooksconfig={}: 这是钩子配置的字典,用于传递配置选项给钩子。

runtime_hooks=[]: 这是运行时钩子脚本的路径列表,这些脚本将在程序开始执行之前运行。

excludes=[]: 这是将被排除在打包之外的模块列表。

noarchive=False: 如果设置为 True,则不会创建 Python 库归档文件,而是将它们作为单独的文件包含。

optimize=0: 设置 Python 优化级别,0 表示不优化,1 表示去除断言,2 表示优化字节码。

pyz = PYZ(a.pure): 创建一个 PYZ 对象,这是一个包含所有纯 Python 代码(不包含二进制扩展)的压缩包。

13-30. exe = EXE(...): 创建一个可执行文件对象,包含以下参数:

  • - pyz: 上一步创建的 PYZ 对象。

  • - a.scripts: 由 Analysis 对象确定的脚本列表。

  • - a.binaries: 由 Analysis 对象确定的二进制文件列表。

  • - a.datas: 由 Analysis 对象确定的数据文件列表。

  • - []: 不明参数,通常为空列表。

  • - name='predict_tianjin': 生成的可执行文件的基本名称。

  • - debug=False: 如果设置为 True,则生成调试信息。

  • - bootloader_ignore_signals=False: 控制是否让引导加载程序忽略信号。

  • - strip=False: 如果设置为 True,则从二进制文件中移除符号信息。

  • - upx=True: 如果设置为 True,则使用 UPX 压缩可执行文件。

  • - upx_exclude=[]: 不使用 UPX 压缩的文件列表。

  • - runtime_tmpdir=None: 运行时的临时目录。

  • - console=True: 如果设置为 True,则创建控制台应用程序。

  • - disable_windowed_traceback=False: 控制是否禁用窗口化的回溯。

  • - argv_emulation=False: 控制是否启用 argv 模拟。

  • - target_arch=None: 指定目标架构,例如 'x86' 或 'x64'。

  • - codesign_identity=None: 用于代码签名的标识。

总结:

通过本文的详细介绍,我们深入了解了PyInstaller这一强大的Python应用打包工具。从基础用法到高级功能,PyInstaller以其丰富的选项和灵活的配置,满足了不同场景下的打包需求。无论是简单的脚本打包,还是复杂的项目部署,PyInstaller都能提供有力的支持。通过掌握PyInstaller,我们不仅能够提升开发效率,还能让Python应用的分发与部署变得更加简单、快捷。希望本文能够成为你Python开发之路上的得力助手,助你轻松应对各种打包挑战。

pyinstaller python 打包
THE END
蜜芽
故事不长,也不难讲,四字概括,毫无意义。

相关推荐

使用PyInstaller将Python程序打包成Windows可执行文件(详细指南)
在开发 Python 应用程序时,有时我们需要将脚本打包成独立的可执行文件(.exe),以便于在没有安装 Python 环境的计算机上运行。本文将介绍如何使用 PyInstaller 工具将 Pyth...
2025-04-11 编程技术
655

PEX:开源Python打包神器,一键打包,随处运行!
PEX(Python EXecutable)是由Pantsbuild团队维护的开源项目(Apache-2.0协议),致力于解决Python应用跨环境部署难、依赖管理混乱的行业痛点。通过将代码、依赖库乃至Python解释...
2025-02-24 编程技术
645

Python项目打包成apk或者其他应用程序的方法详解
随着Python语言的广泛应用,越来越多的开发者开始使用Python来开发各种应用程序。然而,在实际应用中,我们往往需要将Python项目打包成可执行文件,以便在不同的平台上运行。...
2025-01-06 编程技术
434