Python代码打包为单个可执行文件实现过程

 更新时间:2025年09月25日 09:32:19   作者:Q.V.Q  
文章对比了Nuitka与PyInstaller两种Python打包工具,前者将代码编译为C/C++生成高效执行文件,但打包慢且部分库不兼容;后者可生成单文件且易用,但运行时产生临时文件,均需处理依赖项,PyInstaller支持自定义配置文件,Nuitka可通过插件优化性能

目前最常用的两种方法是使用 NuitkaPyInstaller

  • PyInstaller:这是一个非常流行的工具,可以将Python脚本打包为单个可执行文件,支持Windows、macOS和Linux。它还能够自动检测并包含大多数Python包和库。优点是简单易用,缺点是在运行时会释放一堆临时文件。
  • Nuitka: 是将Python代码编译为C/C++代码的编译器,然后再使用C/C++编译器生成可执行文件。与其他打包工具相比,它能产生性能更优的可执行文件。优点是打包后文件执行效率高,缺点是打包速度慢且某些库不兼容。

PyInstaller

1. 安装

pip install pyinstaller

2. 基本用法

pyinstaller main.py
pyinstaller --onefile main.py
pyinstaller --onefile --name=hello main.py

3. 常用参数

参数说明
--onefile将所有依赖打包成一个单独的可执行文件。没有这个选项时,生成的可执行文件将依赖于多个文件
--windowed打包为 GUI 应用程序,不显示控制台窗口(仅适用于 Windows 和 macOS)
--name指定生成的可执行文件的名称
--icon为生成的可执行文件指定图标文件。图标文件通常为 .ico(Windows)或 .icns(macOS)格式。
--add-data添加额外的数据文件。格式为 source:destination,其中 source 是本地路径,destination 是可执行文件内的路径。
--hidden-import手动指定需要包含的模块。如果某些模块在运行时动态导入,PyInstaller 可能无法自动检测到这些依赖项
--exclude-module手动排除某些模块

示例用法如下:

pyinstaller --onefile \
            --windowed \
            --name=my_program \
            --icon=assets/app_icon.ico \
            --add-data="resources/config.json;resources" \
            --hidden-import=json \
            main.py

4. 配置文件

PyInstaller 在首次运行时会生成一个 .spec 文件,这个文件定义了打包的所有配置。你可以编辑这个文件来自定义打包过程。

在生成的 my_program.spec 文件中,你可以自定义一些高级选项,比如添加额外的数据文件、指定打包目录等。

例如,添加一个额外的数据文件到 datas 列表中:

datas=[('data_folder/*', 'data')]

使用自定义的 .spec 文件进行打包:

pyinstaller my_program.spec

5. 常见问题

pyinstaller 执行后报错通常为以下类似问题,手动导入模块即可解决

# 未正常导入:Crypto.Cipher.PKCS1_v1_5 
ImportError: cannot import name 'PKCS1_v1_5' from 'Crypto.Cipher'

# 未正常导入:Crypto.PublicKey.RSA
ImportError: cannot import name 'RSA' from 'Crypto.PublicKey'

# 未正常导入:boto3
ModuleNotFoundError: No module named 'boto3'

# 未正常导入:tqdm
ModuleNotFoundError: No module named 'tqdm'

Nuitka

1. 安装

pip install nuitka

同时确保安装了 C 编译器,如 gcc(Linux)、clang(macOS)、msvc(Windows)或者 MinGW-w64(Windows)。

在 Windows 上,建议使用 MinGW-w64。

2. 打包命令

nuitka --standalone main.py

# 使用pandas
nuitka --standalone --onefile --plugin-enable=pandas  script.py

# 使用tkinter、numpy
nuitka --standalone --follow-imports --plugin-enable=tk-inter --plugin-enable=numpy example.py

# 打包为单文件
nuitka --standalone --onefile --show-progress  --lto=yes script.py

3. 常用参数

  • --standalone:生成一个包含所有依赖的目录
  • --onefile:将所有内容打包成一个单一的可执行文件,pip install zstandard 可减小大小
  • --follow-imports:自动导入所需模块
  • --plugin-enable:用于启用特定的编译插件,例如:tkinter、PyQt5、Numpy等
  • --show-progress:展示打包进度
  • --windows-icon:指定程序图标
  • --windows-disable-console:去掉控制台窗口
  • --lto=yes:启用链接时优化(Link Time Optimization),可以生成更小、更快的二进制文件。

4. 其他用途

编译 .py 文件为 .pyd

nuitka --module your_script.py

总结

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。

相关文章

  • 详解Python中dbm模块和shelve模块的使用

    详解Python中dbm模块和shelve模块的使用

    这篇文章主要为大家详细介绍了Python中dbm模块和shelve模块的具体用法,文中的示例代码简洁易懂,对我们深入学习Python有一定的帮助,需要的可以参考下
    2023-10-10
  • PyCharm+Pipenv虚拟环境开发和依赖管理的教程详解

    PyCharm+Pipenv虚拟环境开发和依赖管理的教程详解

    这篇文章主要介绍了PyCharm+Pipenv虚拟环境作开发和依赖管理的教程,本文通过图文并茂的形式给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2020-04-04
  • OpenCV根据面积筛选连通域学习示例

    OpenCV根据面积筛选连通域学习示例

    这篇文章主要为大家介绍了OpenCV根据面积筛选连通域学习示例,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2022-06-06
  • Python开发编码规范

    Python开发编码规范

    Python开发编码规范...
    2006-09-09
  • Python 的 with 语句详解

    Python 的 with 语句详解

    这篇文章主要介绍了Python 的 with 语句,本文详细讲解了with语句、with语句的历史、with语句的使用例子等,需要的朋友可以参考下
    2014-06-06
  • django框架基于queryset和双下划线的跨表查询操作详解

    django框架基于queryset和双下划线的跨表查询操作详解

    这篇文章主要介绍了django框架基于queryset和双下划线的跨表查询操作,结合实例形式详细分析了Django框架queryset和双下划线的跨表查询相关实现技巧与操作注意事项,需要的朋友可以参考下
    2019-12-12
  • Python Pygame实现兔子猎人守护城堡游戏

    Python Pygame实现兔子猎人守护城堡游戏

    这篇文章主要介绍了用python来制作的一个守护类小游戏兔子猎人守护城堡,文中的示例代码介绍得很详细,感兴趣的小伙伴快来跟随小编一起学习学习吧
    2021-12-12
  • python 图像处理画一个正弦函数代码实例

    python 图像处理画一个正弦函数代码实例

    这篇文章主要介绍了python 图像处理画一个正弦函数代码实例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2019-09-09
  • Python中顺序表的实现简单代码分享

    Python中顺序表的实现简单代码分享

    这篇文章主要介绍了Python中顺序表的实现简单代码分享,展示了代码运行结果,然后分享了相关实例代码,具有一定借鉴价值,需要的朋友可以参考下
    2018-01-01
  • Tensorflow实现神经网络拟合线性回归

    Tensorflow实现神经网络拟合线性回归

    这篇文章主要为大家详细介绍了Tensorflow实现神经网络拟合线性回归,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2019-07-07

最新评论