当前位置: 首页 > news >正文

Nuitka 打包Python程序

文章目录

  • Nuitka 打包Python程序
      • 🚀 **一、Nuitka 核心优势**
      • ⚙️ **二、环境准备(Windows 示例)**
      • 📦 **三、基础打包命令**
        • **单文件脚本打包**
        • **带第三方库的项目**
      • 🛠️ **四、高级配置选项**
        • **示例:完整命令**
      • ⚠️ **五、常见问题与解决**
      • 📊 **六、Nuitka vs 其他工具**
      • 💎 **七、最佳实践建议**
      • 💡 **八、使用举例**
      • 总结

Nuitka 打包Python程序

需要把Python写的代码打包给朋友,于是通过DeepSeek检索了Nuitka的使用,之前用过pyinstaller,参考我的博客PySide6 GUI 学习笔记——Python文件编译打包,这次我采用Nuitka打包一个简单的程序。
以下是使用 Nuitka 将 Python 程序打包为独立 EXE 文件的完整指南,结合核心优势、详细步骤和避坑技巧:


🚀 一、Nuitka 核心优势

  1. 性能卓越
    • 将 Python 编译为 C++ 代码,运行速度比传统打包工具快 30%-300%。
    • 支持 SIMD 指令集优化(如 AVX2/SSE4),适合高频计算场景(金融量化、工业视觉)。
  2. 安全加固
    • 三重防护机制:控制流扁平化、字符串常量加密(AES-256-CTR)、元数据混淆,大幅提高反编译成本。
  3. 体积控制
    • 基础增量仅 2-5MB,支持 UPX 压缩(体积减少 60%)。
  4. 跨平台支持
    • 兼容 Windows/macOS/Linux,完美支持 Python 3.4-3.13 和 Python 2.7。

⚙️ 二、环境准备(Windows 示例)

  1. 安装依赖
    • 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:显式包含动态导入的库(如 numpyrequests)。

🛠️ 四、高级配置选项

参数作用
--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

⚠️ 五、常见问题与解决

  1. 动态导入失败

    • 现象importlib.import_module("mod") 未包含依赖。
    • 解决:添加 --include-package=mod--include-module=mod
  2. 杀毒软件误报

    • 解决:编译时添加数字签名,或提交至杀毒软件白名单。
  3. 大型库(如 PyTorch)打包失败

    • 解决:显式启用插件和依赖:
      python -m nuitka --standalone --include-module=torch._C --include-package=torch-static app.py
      
  4. 编译速度慢

    • 优化:使用 --jobs=N 多线程编译,或跳过调试信息 --disable-console

📊 六、Nuitka vs 其他工具

特性NuitkaPyInstallercx_Freeze
执行速度⭐⭐⭐⭐⭐ (快 30-300%)⭐⭐⭐⭐⭐
加密强度⭐⭐⭐⭐⭐⭐⭐⭐⭐⭐
体积控制⭐⭐⭐⭐ (支持 UPX)⭐⭐⭐⭐⭐
依赖处理智能分析依赖树需手动指定需复杂配置
适用场景商业分发/高性能计算简单脚本高度自定义项目

💎 七、最佳实践建议

  1. 使用虚拟环境

    • 通过 Miniconda 创建隔离环境,避免冗余依赖:
      conda create -n pack_env python=3.10
      conda activate pack_env
      pip install nuitka pandas numpy
      
  2. 分离资源文件

    • 数据文件通过 --include-data-dir=res/;res/ 打包,代码内用 sys._MEIPASS 访问。
  3. 敏感信息保护

    • 结合 Cython 混合编译核心模块(先转 .pyx 再编译):
      # setup_cython.py
      from distutils.core import setup
      from Cython.Build import cythonize
      setup(ext_modules=cythonize("secret_module.pyx"))
      
      再用 Nuitka 打包主程序。

💡 八、使用举例

我有一个名为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 官方文档 查询插件支持列表。

http://www.lqws.cn/news/526663.html

相关文章:

  • NoSQL之Redis集群
  • 智慧生产管控数字化平台(源码+文档+讲解+演示)
  • Datax报错:在有总bps限速条件下,单个channel的bps值不能为空,也不能为非正数
  • Flutter 多平台项目开发指南
  • 使用Charles中文版抓包工具进行高效的API调试与性能优化
  • openharmony 性能检测工具
  • [架构之美]Spring Boot 3.5.3新特性解析及JDK21集成
  • Socket 编程 TCP
  • 小程序入门:理解小程序页面配置
  • ZYNQ GP总线深度实战:智能灯光控制器的PS-PL交互艺术
  • 128K 长文本处理实战:腾讯混元 + 云函数 SCF 构建 PDF 摘要生成器
  • 如何解决本地DNS解析失败问题?以连接AWS ElastiCache Redis为例
  • 华曦达港股IPO递表,AI Home生态构建智能生活新蓝图
  • dockercompose快速安装ELK
  • 设计模式 | 原型模式
  • 分布式I/O在风电行业的应用
  • 向量数据库milvus中文全文检索取不到数据的处理办法
  • Python 惰性求值实战:用生成器重构 Sentence 类
  • Milvus中 Collections 级多租户 和 分区级多租户 的区别
  • kubernetes架构原理
  • 【Docker基础】Docker容器管理:docker rm及其参数详解
  • Axure版TDesign 组件库-免费版
  • Ubuntu中使用netcat发送16进制网络数据包
  • android 11.0 打开ALOGV ALOGI ALOGD日志输出的方法
  • git 多用户管理 跨平台
  • 远程玩3A大作要多少帧?ToDesk、向日葵、UU远程性能对决
  • mysql 安装vc++2013 没有权限问题。
  • 使用 DHTMLX Gantt 添加迷你地图:提升大型项目可视化与导航体验
  • 996引擎-假人系统
  • el-select封装下拉加载组件