PyInstaller打包Python脚本的使用示例

 更新时间:2025年04月30日 09:32:53   作者:Tiandaren  
本文主要介绍了PyInstaller打包Python脚本的使用示例,通过 PyInstaller,可以将Python脚本打包成 .exe文件(适用于 Windows)或适用于 macOS 和 Linux 的可执行文件,感兴趣的可以了解一下

1. 写在前面

通常,在用 Python 编写完一个脚本后,需要将它部署并集成到一个更大的项目中。常见的集成方式有以下几种:

  • 使用 PyInstaller 打包。
  • 使用 Docker 打包。
  • 将 Python 嵌入到 C++ 代码中,并封装成类。
  • 将 Python 代码转换为 C++ 代码。

本文介绍其中一种方式——使用 PyInstaller 打包。通过 PyInstaller,可以将 Python 脚本打包成 .exe 文件(适用于 Windows)或适用于 macOS 和 Linux 的可执行文件,用户无需安装 Python 或任何相关依赖,便能直接运行程序。

主要优势:

  • 将 Python 脚本打包成独立可执行文件,方便分发和运行。
  • 支持单文件打包、图标定制、以及额外文件的捆绑。
  • 可选隐藏控制台窗口,适合图形化应用(GUI)程序。

适用场景:

  • 发布桌面工具或命令行程序。
  • 让没有 Python 环境的用户也能使用你的工具。
  • 分享自包含的 Python 项目,确保目标机器能够顺利运行。

2. 打包指令解析与参数详解

参数名描述示例类型必须默认值
--onefile将所有依赖文件打包为单个可执行文件。pyinstaller --onefile example.pyboolFalse
--noconsole隐藏控制台窗口(适用于 GUI 应用)。pyinstaller --noconsole gui_app.pyboolFalse
--name指定生成的可执行文件名称。pyinstaller --name=my_app example.pystr源文件名(无扩展)
--icon设置可执行文件的图标(需提供 .ico 文件)。pyinstaller --icon=app_icon.ico example.pystrNone
--add-data捆绑额外文件(如配置文件、静态资源等)。pyinstaller --add-data "config.yaml;." example.pystrNone
--clean清理之前的构建缓存,强制重新打包。pyinstaller --clean example.pyboolFalse
--hidden-import手动添加隐藏的依赖模块(通常是自动检测遗漏的依赖)。pyinstaller --hidden-import=requests example.pylist自动检测

3. 基础步骤

1. 安装 PyInstaller

在终端(或命令行)中运行以下命令,安装 PyInstaller:

pip install pyinstaller

2. 使用基础命令进行打包

假设你有一个 Python 脚本 example_script.py,使用下面的命令将其打包为一个独立的可执行文件:

pyinstaller --onefile example_script.py
  • 该命令会将所有依赖项和代码打包成一个单一的 .exe 文件。
  • 打包后,可以在 dist 目录下找到生成的可执行文件。

4. 常见的用法示例

示例 1:基础打包

将 example_script.py 打包为一个单文件可执行程序:

pyinstaller --onefile example_script.py

示例 2:自定义名称和图标

将输出文件命名为 my_program.exe,并指定图标文件为 app_icon.ico

pyinstaller --onefile --name=my_program --icon=app_icon.ico example_script.py

示例 3:捆绑额外文件

将配置文件 config.yaml 一起捆绑进可执行文件:

pyinstaller --onefile --add-data "config.yaml;." example_script.py

注意:在 Windows 系统中,路径分隔符用分号 ;,而在 macOS/Linux 中使用冒号 :

示例 4:解决缺失依赖问题

如果在运行时遇到某个模块丢失的错误,可以通过 --hidden-import 指定手动引入依赖:

pyinstaller --onefile --hidden-import=requests example_script.py

示例 5:隐藏控制台窗口

适用于图形界面(GUI)应用程序,运行时隐藏控制台窗口:

pyinstaller --onefile --noconsole gui_app.py

5. 注意事项(路径)

  • 路径问题:使用 --add-data 时,不同操作系统的路径分隔符需特别注意。

    • Windows:"source;destination"
    • macOS/Linux:"source:destination"
  • 文件路径问题:在代码中访问本地文件时,使用相对路径获取的文件可能会在打包后无法找到。此时,建议使用以下方式获取正确的文件路径:

BASE_DIR = os.path.dirname(os.path.realpath(sys.argv[0]))

6. 错误处理和日志记录

在打包的 Python 应用中,为了方便调试,可以加入错误处理代码,将错误信息记录到文件中,帮助定位问题。

try:
    # 代码逻辑
    pass
except Exception as e:
    print("An error occurred:", e)
    with open("error_log.txt", "w") as f:
        f.write(str(e))

如果可执行文件出现问题,能够在 error_log.txt 中查看详细的错误信息。

例如,

在这里插入图片描述

这就是一个文件路径错误的报错,原因在于生成的可执行文件是在 dist 目录下,但是文件路径是相对路径,在 ../ 上,知道问题就可以解决了。否则,有时候连报错都不知道在哪。

另外,如果想要更加优雅地打包python,建议配合以下教程食用:
Python 参数配置使用 XML 文件的教程:轻松管理你的项目配置

到此这篇关于PyInstaller打包Python脚本的使用示例的文章就介绍到这了,更多相关PyInstaller打包Python脚本内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • Python实现京东秒杀功能代码

    Python实现京东秒杀功能代码

    这篇文章主要介绍了Python实现京东秒杀功能,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2019-05-05
  • ubuntu 安装pyqt5和卸载pyQt5的方法

    ubuntu 安装pyqt5和卸载pyQt5的方法

    这篇文章主要介绍了ubuntu 安装pyqt5和卸载pyQt5的方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-03-03
  • python中import与from方法总结(推荐)

    python中import与from方法总结(推荐)

    这篇文章主要介绍了python中import与from方法总结,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2019-03-03
  • 关于Tensorflow使用CPU报错的解决方式

    关于Tensorflow使用CPU报错的解决方式

    今天小编就为大家分享一篇关于Tensorflow使用CPU报错的解决方式,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2020-02-02
  • Python 中strip()函数详细说明及使用方法

    Python 中strip()函数详细说明及使用方法

    strip()函数是Python字符串方法之一,用于处理字符串的前导和尾随空白字符,它返回一个新字符串,该字符串是原始字符串去除前导和尾随空格(包括空格、制表符、换行符等)后的结果,这篇文章主要介绍了Python 中strip()函数详细说明及使用方法,需要的朋友可以参考下
    2024-02-02
  • 详解Python常用标准库之时间模块time和datetime

    详解Python常用标准库之时间模块time和datetime

    time和datetime是Python中常用的两个时间模块,本文将通过示例详细为大家讲讲二者的使用方法,感兴趣的小伙伴可以跟随小编一起学习学习
    2022-05-05
  • Keras 实现加载预训练模型并冻结网络的层

    Keras 实现加载预训练模型并冻结网络的层

    这篇文章主要介绍了Keras 实现加载预训练模型并冻结网络的层,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2020-06-06
  • python自动化测试之异常及日志操作实例分析

    python自动化测试之异常及日志操作实例分析

    这篇文章主要介绍了python自动化测试之异常及日志操作,结合实例形式分析了python自动化测试中的异常捕获与日志记录相关操作技巧,需要的朋友可以参考下
    2019-11-11
  • 在Ubuntu系统中运行python代码的几个步骤

    在Ubuntu系统中运行python代码的几个步骤

    项目中需要在Linux上运行自己写的python脚本,特此记录一下操作流程,整个流程比较简单,下面这篇文章主要给大家介绍了关于在Ubuntu系统中运行python代码的几个步骤,需要的朋友可以参考下
    2023-12-12
  • Python实现PDF扫描件生成DOCX或EXCEL功能

    Python实现PDF扫描件生成DOCX或EXCEL功能

    这篇文章主要介绍了如何利用Python实现将PDF扫描件转为DOCX或EXCEL文件格式功能,文中的示例代码讲解详细,需要的小伙伴可以参考一下
    2022-03-03

最新评论