Nuitka 打包Python程序
文章目录
- Nuitka 打包Python程序
- 🚀 **一、Nuitka 核心优势**
- ⚙️ **二、环境准备(Windows 示例)**
- 📦 **三、基础打包命令**
- **单文件脚本打包**
- **带第三方库的项目**
- 🛠️ **四、高级配置选项**
- **示例:完整命令**
- ⚠️ **五、常见问题与解决**
- 📊 **六、Nuitka vs 其他工具**
- 💎 **七、最佳实践建议**
- 💡 **八、使用举例**
- 总结
Nuitka 打包Python程序
需要把Python写的代码打包给朋友,于是通过DeepSeek检索了Nuitka的使用,之前用过pyinstaller,参考我的博客PySide6 GUI 学习笔记——Python文件编译打包,这次我采用Nuitka打包一个简单的程序。
以下是使用 Nuitka 将 Python 程序打包为独立 EXE 文件的完整指南,结合核心优势、详细步骤和避坑技巧:
🚀 一、Nuitka 核心优势
- 性能卓越
- 将 Python 编译为 C++ 代码,运行速度比传统打包工具快 30%-300%。
- 支持 SIMD 指令集优化(如 AVX2/SSE4),适合高频计算场景(金融量化、工业视觉)。
- 安全加固
- 三重防护机制:控制流扁平化、字符串常量加密(AES-256-CTR)、元数据混淆,大幅提高反编译成本。
- 体积控制
- 基础增量仅 2-5MB,支持 UPX 压缩(体积减少 60%)。
- 跨平台支持
- 兼容 Windows/macOS/Linux,完美支持 Python 3.4-3.13 和 Python 2.7。
⚙️ 二、环境准备(Windows 示例)
- 安装依赖
- Python 环境:推荐 Python 3.10+(需与目标环境一致)。
- C 编译器:安装 MinGW64(选择
x86_64-posix-seh
版本),并添加C:\mingw64\bin
到系统 PATH。 - 验证安装:
pip install nuitka python -m nuitka --version # 输出版本号即成功
📦 三、基础打包命令
单文件脚本打包
python -m nuitka --standalone --onefile your_script.py
--standalone
:生成独立 EXE(包含所有依赖)。--onefile
:输出为单个 EXE 文件。- 输出位置:生成
your_script.dist
目录,内含 EXE 文件。
带第三方库的项目
python -m nuitka --standalone --onefile --include-package=numpy,requests app.py
--include-package
:显式包含动态导入的库(如numpy
、requests
)。
🛠️ 四、高级配置选项
参数 | 作用 |
---|---|
--enable-plugin=tk-inter | 启用 GUI 插件支持(如 Tkinter/PyQt) |
--windows-icon=app.ico | 设置 EXE 图标(需 .ico 格式) |
--remove-output | 编译后删除临时文件 |
--jobs=4 | 多线程编译加速(根据 CPU 核心数调整) |
--lto=yes | 启用链接时优化(提升运行效率) |
--disable-console | 隐藏控制台窗口(适用于 GUI 程序) |
示例:完整命令
python -m nuitka --standalone --onefile --enable-plugin=pyqt5 --windows-icon=app.ico --jobs=4 app.py
⚠️ 五、常见问题与解决
-
动态导入失败
- 现象:
importlib.import_module("mod")
未包含依赖。 - 解决:添加
--include-package=mod
或--include-module=mod
。
- 现象:
-
杀毒软件误报
- 解决:编译时添加数字签名,或提交至杀毒软件白名单。
-
大型库(如 PyTorch)打包失败
- 解决:显式启用插件和依赖:
python -m nuitka --standalone --include-module=torch._C --include-package=torch-static app.py
- 解决:显式启用插件和依赖:
-
编译速度慢
- 优化:使用
--jobs=N
多线程编译,或跳过调试信息--disable-console
。
- 优化:使用
📊 六、Nuitka vs 其他工具
特性 | Nuitka | PyInstaller | cx_Freeze |
---|---|---|---|
执行速度 | ⭐⭐⭐⭐⭐ (快 30-300%) | ⭐⭐ | ⭐⭐⭐ |
加密强度 | ⭐⭐⭐⭐⭐ | ⭐⭐ | ⭐⭐⭐ |
体积控制 | ⭐⭐⭐⭐ (支持 UPX) | ⭐⭐ | ⭐⭐⭐ |
依赖处理 | 智能分析依赖树 | 需手动指定 | 需复杂配置 |
适用场景 | 商业分发/高性能计算 | 简单脚本 | 高度自定义项目 |
💎 七、最佳实践建议
-
使用虚拟环境
- 通过 Miniconda 创建隔离环境,避免冗余依赖:
conda create -n pack_env python=3.10 conda activate pack_env pip install nuitka pandas numpy
- 通过 Miniconda 创建隔离环境,避免冗余依赖:
-
分离资源文件
- 数据文件通过
--include-data-dir=res/;res/
打包,代码内用sys._MEIPASS
访问。
- 数据文件通过
-
敏感信息保护
- 结合 Cython 混合编译核心模块(先转
.pyx
再编译):
再用 Nuitka 打包主程序。# setup_cython.py from distutils.core import setup from Cython.Build import cythonize setup(ext_modules=cythonize("secret_module.pyx"))
- 结合 Cython 混合编译核心模块(先转
💡 八、使用举例
我有一个名为google_click.py的文件,需要打包成exe文件,使用了如下的命令:
python -m nuitka --standalone --onefile --jobs=8 --output-dir=out --lto=
yes google_click.py
运行过程如下:
Nuitka-Options: Used command line options:
Nuitka-Options: --standalone --onefile --jobs=8 --output-dir=out --lto=yes google_click.py
Nuitka: Starting Python compilation with:
Nuitka: Version '2.7.10' on Python 3.12 (flavor 'Unknown') commercial grade 'not installed'.
Nuitka-Plugins:options-nanny: Using module 'trio._core._ki' (version 0.30.0) with incomplete support: Disabled careful
Nuitka-Plugins:options-nanny: handling of KeyboardInterrupt in 'trio'
Nuitka-Plugins:anti-bloat: Not including 'pandas.core._numba.extensions' automatically in order to avoid bloat, but this may
Nuitka-Plugins:anti-bloat: cause: no numba acceleration.
Nuitka: Completed Python level compilation and optimization.
Nuitka: Generating source code for C backend compiler.
Nuitka: Running data composer tool for optimal constant value handling.
Nuitka: Running C compilation via Scons.
Nuitka-Scons: Backend C compiler: cl (cl 14.3).
Nuitka-Scons: Backend C linking with 723 files (no progress information available for this stage).
Nuitka-Scons: Compiled 723 C files using clcache with 0 cache hits and 723 cache misses.
Nuitka-Plugins:dll-files: Found 1 file DLLs from selenium installation.
Nuitka will make use of Dependency Walker (https://dependencywalker.com) tool
to analyze the dependencies of Python extension modules.Is it OK to download and put it in 'C:\Users\yeshe\AppData\Local\Nuitka\Nuitka\Cache\DOWNLO~1\depends\x86_64'.Fully automatic, cached. Proceed and download? [Yes]/No : yes
Nuitka: Downloading 'https://dependencywalker.com/depends22_x64.zip'.
Nuitka: Extracting to 'C:\Users\yeshe\AppData\Local\Nuitka\Nuitka\Cache\DOWNLO~1\depends\x86_64\depends.exe'
Nuitka-Plugins:data-files: Included data file 'certifi\cacert.pem' due to package data for 'certifi'.
Nuitka-Plugins:data-files: Included data file 'pandas\io\formats\templates\html.tpl' due to package data directory 'templates'
Nuitka-Plugins:data-files: for 'pandas.io.formats'.
Nuitka-Plugins:data-files: Included data file 'pandas\io\formats\templates\html_style.tpl' due to package data directory
Nuitka-Plugins:data-files: 'templates' for 'pandas.io.formats'.
Nuitka-Plugins:data-files: Included data file 'pandas\io\formats\templates\html_table.tpl' due to package data directory
Nuitka-Plugins:data-files: 'templates' for 'pandas.io.formats'.
Nuitka-Plugins:data-files: Included data file 'pandas\io\formats\templates\latex.tpl' due to package data directory
Nuitka-Plugins:data-files: 'templates' for 'pandas.io.formats'.
Nuitka-Plugins:data-files: Included data file 'pandas\io\formats\templates\latex_longtable.tpl' due to package data directory
Nuitka-Plugins:data-files: 'templates' for 'pandas.io.formats'.
Nuitka-Plugins:data-files: Included data file 'pandas\io\formats\templates\latex_table.tpl' due to package data directory
Nuitka-Plugins:data-files: 'templates' for 'pandas.io.formats'.
Nuitka-Plugins:data-files: Included data file 'pandas\io\formats\templates\string.tpl' due to package data directory
Nuitka-Plugins:data-files: 'templates' for 'pandas.io.formats'.
Nuitka-Plugins:data-files: Included 604 data files due to package data directory 'zoneinfo' for 'pytz'.
Nuitka-Plugins:data-files: Included data file 'selenium\webdriver\common\mutation-listener.js' due to package data directory
Nuitka-Plugins:data-files: '.' for 'selenium'.
Nuitka-Plugins:data-files: Included data file 'selenium\webdriver\common\linux\selenium-manager' due to package data directory
Nuitka-Plugins:data-files: '.' for 'selenium'.
Nuitka-Plugins:data-files: Included data file 'selenium\webdriver\common\macos\selenium-manager' due to package data directory
Nuitka-Plugins:data-files: '.' for 'selenium'.
Nuitka-Plugins:data-files: Included data file 'selenium\webdriver\firefox\webdriver_prefs.json' due to package data directory
Nuitka-Plugins:data-files: '.' for 'selenium'.
Nuitka-Plugins:data-files: Included data file 'selenium\webdriver\remote\findElements.js' due to package data directory '.'
Nuitka-Plugins:data-files: for 'selenium'.
Nuitka-Plugins:data-files: Included data file 'selenium\webdriver\remote\getAttribute.js' due to package data directory '.'
Nuitka-Plugins:data-files: for 'selenium'.
Nuitka-Plugins:data-files: Included data file 'selenium\webdriver\remote\isDisplayed.js' due to package data directory '.' for
Nuitka-Plugins:data-files: 'selenium'.
Nuitka-Postprocessing: Creating single file from dist folder, this may take a while.
Nuitka-Onefile: Running bootstrap binary compilation via Scons.
Nuitka-Scons: Onefile C compiler: cl (cl 14.3).
Nuitka-Scons: Onefile C linking.
Nuitka-Scons: Compiled 1 C files using clcache with 0 cache hits and 1 cache misses.
Nuitka-Onefile: Using compression for onefile payload.
Nuitka-Onefile: Onefile payload compression ratio (24.35%) size 152398972 to 37107219.
Nuitka-Onefile: Keeping onefile build directory 'out\google_click.onefile-build'.
Nuitka: Keeping dist folder 'out\google_click.dist' for inspection, no need to use it.
Nuitka: Keeping build directory 'out\google_click.build'.
Nuitka: Successfully created 'D:\Source\Repos\Visual Studio Code\some_selenium_app\out\google_click.exe'.
我指定里一个out文件夹,生成的独立运行文件放在了该文件夹中:
总结
Nuitka 凭借编译级优化和工业级安全,已成为 Python 打包的首选方案,尤其适合:
- 🔒 商业软件分发(防源码泄露)
- ⚡ 高频计算场景(实时数据处理)
- 🔧 混合 C/C++ 项目(如深度学习框架集成)
命令模板:
python -m nuitka --standalone --onefile --enable-plugin=upx --jobs=4 --lto=yes app.py
遇到复杂依赖时,优先通过 --include-package
显式声明缺失模块,并通过 Nuitka 官方文档 查询插件支持列表。