使用pyinstaller打包py文件的实现步骤

 更新时间:2025年03月19日 08:30:43   作者:无妄无望  
PyInstaller是一个用于将Python脚本打包成独立可执行文件的工具,本文主要介绍了使用pyinstaller打包py文件,具有一定的参考价值,感兴趣的可以了解一下

1、是什么

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

功能特点

  • 跨平台支持:可以在 Windows、macOS 和 Linux 系统上使用。
  • 自动处理依赖项:自动分析脚本的依赖项,并将它们打包到可执行文件中。
  • 生成单个可执行文件:可以将所有依赖项打包到一个单独的可执行文件中,方便分发。
  • 支持多种打包选项:可以指定窗口化应用、隐藏控制台窗口等选项。

2.怎么用 

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、示例

3.1 单个文件打包

(1)打包命令:

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

pyinstaller -F main.py

打包成功

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

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

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

pyinstaller main.spec

 3.2 多个文件的示例

(1)与单个文件相同

(2)修改spec配置文件

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

②  所有资源存在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打包py文件的实现步骤的文章就介绍到这了,更多相关pyinstaller打包py内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家! 

相关文章

  • 详解Python如何使用PyBuilder从零开始构建项目

    详解Python如何使用PyBuilder从零开始构建项目

    PyBuilder是一个用于构建Python项目的工具,它提供了一种简单而强大的方式来管理项目的依赖、运行测试、生成文档等任务,下面就跟随小编一起来学习一下如何使用PyBuilder构建项目吧
    2024-03-03
  • Python中MYSQLdb出现乱码的解决方法

    Python中MYSQLdb出现乱码的解决方法

    这篇文章主要介绍了Python中MYSQLdb出现乱码的解决方法,是Python操作MySQL数据库程序设计中非常常见的问题,需要的朋友可以参考下
    2014-10-10
  • Pandas快速合并多张excel表格的两种方法

    Pandas快速合并多张excel表格的两种方法

    最近学习了python遍历目录,下面这篇文章主要给大家介绍了关于Pandas快速合并多张excel表格的两种方法,文中通过实例代码介绍的非常详细,需要的朋友可以参考下
    2023-01-01
  • Python中Json使用示例详解

    Python中Json使用示例详解

    这篇文章主要介绍了Python中Json使用,主要介绍一下python 中 json的使用 如何把dict转成json 、object 转成json 、以及json转成对象,需要的朋友可以参考下
    2022-07-07
  • 构建高效的python requests长连接池详解

    构建高效的python requests长连接池详解

    这篇文章主要介绍了构建高效的python requests长连接池详解,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2020-05-05
  • Python 实现一个简单的web服务器

    Python 实现一个简单的web服务器

    这篇文章主要介绍了Python 实现一个简单的web服务器的方法,帮助大家更好的理解和学习python,感兴趣的朋友可以了解下
    2021-01-01
  • django第一个项目127.0.0.1:8000不能访问的解决方案详析

    django第一个项目127.0.0.1:8000不能访问的解决方案详析

    django项目服务启动后无法通过127.0.0.1访问,下面这篇文章主要给大家介绍了关于django第一个项目127.0.0.1:8000不能访问的解决方案,需要的朋友可以参考下
    2022-10-10
  • Python通过Ollama调用大语言模型

    Python通过Ollama调用大语言模型

    这篇文章主要为大家详细介绍了如何使用Python通过Ollama调用大语言模型,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下
    2026-03-03
  • python配置文件写入过程详解

    python配置文件写入过程详解

    这篇文章主要介绍了python配置文件写入过程详解,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2019-10-10
  • Python2.X/Python3.X中urllib库区别讲解

    Python2.X/Python3.X中urllib库区别讲解

    本篇文章通过对比给大家详细讲解了在Python2和Python3中urllib库区别以及用法讲解,有需要的朋友跟着学习下吧。
    2017-12-12

最新评论