【Python】6 种方法轻松将 Python 脚本打包成 EXE 应用

引言

Python 凭借其简洁的语法和强大的功能,在数据分析、Web 开发、自动化脚本等领域广受欢迎。它“开箱即用”的特性让开发者能够快速构建原型和应用程序。然而,对于最终用户而言,运行 Python 脚本往往意味着需要预先安装 Python 解释器及相关依赖库,这对非技术背景的用户来说无疑增加了门槛。

为了解决这一问题,将 Python 代码打包成独立的可执行文件(通常在 Windows 上是 .exe 文件)成为了一个非常实用的选择。这样,用户无需任何额外环境配置,就能像运行普通软件一样直接启动您的 Python 应用。本文将为您介绍六种主流且有效的 Python 打包工具,助您轻松实现跨平台分发。

1. PyInstaller: 最流行的选择

PyInstaller 是目前最广为人知、社区支持最广泛的 Python 打包工具之一。它能够很好地处理各种复杂的依赖关系,并支持将整个应用及其所需资源打包成一个或多个独立的可执行文件。

  • 特点
    • 支持 Windows, Linux, macOS。
    • 可以打包成单个文件或包含多个文件的目录。
    • 对大多数 Python 包有良好的兼容性。

基本用法: 在项目根目录下打开终端或命令提示符,执行以下命令即可开始打包:

pyinstaller your_script.py 

默认情况下,会在 dist/ 目录下生成可执行文件。添加 --onefile 参数可以打包成单个 exe 文件。

2. cx_Freeze: 跨平台的老牌选手

cx_Freeze 是一个老牌的跨平台打包工具,同样支持将 Python 程序转换为 Windows、macOS 和 Linux 下的原生可执行文件。

  • 特点
    • 高度跨平台。
    • 配置相对灵活。

基本用法: 通过命令行直接打包:

cxfreeze your_script.py --target-dir dist 

这会将生成的可执行文件及相关依赖放入 dist 目录中。

3. py2exe: Windows 平台专用专家

顾名思义,py2exe 是专为 Windows 平台设计的打包工具。如果您确定目标用户只使用 Windows 系统,那么 py2exe 是一个成熟稳定的选择。

  • 特点
    • 专注于 Windows 平台,针对该系统优化良好。
    • 历史悠久,文档和社区经验丰富。

基本用法py2exe 通常需要配合一个 setup.py 脚本来进行更精细的控制。最基本的打包方式是在 setup.py 中配置好选项后,运行:

python setup.py py2exe 

4. py2app: macOS 平台的对应方案

py2exe 类似,py2app 是专门为 macOS 设计的 Python 打包工具。

  • 特点
    • 专为 macOS 优化。
    • 能够创建符合 macOS 规范的应用程序包 (.app)。

基本用法: 同样需要一个 setup.py 脚本。配置完成后,通过以下命令打包:

python setup.py py2app 

5. Nuitka: 编译加速,性能提升

Nuitka 不仅仅是一个打包工具,它首先是一个 Python 到 C++ 的编译器。它可以将 Python 代码先编译成优化过的 C++ 代码,然后再链接成可执行文件。这不仅能生成独立的 exe,有时还能带来一定的性能提升。

  • 特点
    • 兼具打包和编译功能。
    • 可能提高部分程序的执行速度。
    • 支持多种操作系统。

基本用法: 安装后,直接对 Python 脚本进行编译打包:

nuitka --standalone your_script.py 

--standalone 参数用于生成包含所有依赖的独立文件夹。

6. Nuitka + PyInstaller: 强强联合

这是一个进阶技巧,结合了 Nuitka 的编译优势和 PyInstaller 的打包便利性。

  • 思路
    1. 使用 Nuitka 将 Python 脚本编译成 C++ 代码并生成可执行文件(或模块)。
    2. 再利用 PyInstaller 对 Nuitka 生成的结果进行二次打包,进一步优化结构或处理复杂依赖。

示例流程(简化示意):

# 第一步:用 Nuitka 生成独立结构 nuitka --standalone your_script.py # 第二步:可能需要手动调整或使用 PyInstaller 处理特定需求 # 注意:这里的 `your_script.spec` 需要根据实际情况编写或由 PyInstaller 生成并修改 # pyinstaller your_script.spec 
注意: 这种组合使用较为复杂,通常用于对性能和打包结果有特殊要求的场景。PyInstaller 通常可以直接处理纯 Python 项目,不一定需要 Nuitka 预编译。

结语

将 Python 脚本打包成 EXE 文件极大地简化了应用程序的部署和分发过程。从功能全面、易于使用的 PyInstaller,到平台专用的 py2exe 和 py2app,再到追求性能的 Nuitka,每种工具都有其独特的优势和适用场景。

  • 如果您寻求通用性和简便性PyInstaller 通常是首选。
  • 如果您专注于 WindowsmacOS 单一平台,py2exepy2app 提供了针对性的良好支持。
  • 如果您希望获得潜在的性能提升或者尝试不同的技术路线,Nuitka 是一个值得探索的方向。

Read more

Flutter 组件 activity_files 适配鸿蒙 HarmonyOS 实战:文件活动流治理,构建高性能存储沙箱访问与资产全生命周期管理架构

Flutter 组件 activity_files 适配鸿蒙 HarmonyOS 实战:文件活动流治理,构建高性能存储沙箱访问与资产全生命周期管理架构

欢迎加入开源鸿蒙跨平台社区:https://openharmonycrossplatform.ZEEKLOG.net Flutter 组件 activity_files 适配鸿蒙 HarmonyOS 实战:文件活动流治理,构建高性能存储沙箱访问与资产全生命周期管理架构 前言 在鸿蒙(OpenHarmony)生态迈向全场景分布式协同、涉及海量多媒体资产处理及严苛应用沙箱(Sandbox)隔离的背景下,如何实现一套既能穿透复杂的层级目录、又能实时追踪文件变更活动且具备极高 I/O 吞吐能力的存储治理架构,已成为决定应用性能广度与数据安全深度。在鸿蒙设备这类强调 AOT 极致性能与受限文件权限周期的环境下,如果应用依然采用陈旧的同步文件读取或缺乏活动追踪的直接 I/O,由于由于频繁的磁盘竞争,极易由于由于“主线程阻塞”或“资产状态不同步”导致用户在管理大型媒体库时发生明显的感知性卡顿。 我们需要一种能够解耦文件路径、支持异步流式追踪(Activity Tracking)且符合鸿蒙分布式文件系统安全范式的操作框架。 activity_files 为 Flutter 开发者引入了“

By Ne0inhk

Mysql超详细安装配置教程(保姆级)

MySQL 一、下载 MySQL (一)下载地址 官网下载社区版 MySQL,推荐选择 MySQL 8.0.44 社区版(稳定版,兼容性强),下载地址:MySQL Community Downloads (二)下载步骤 1. Select Operating System 选择 Microsoft Windows; 2. 下载选项选择: * 推荐:Windows (x86, 64-bit), ZIP Archive(免安装压缩包,灵活配置),文件大小约 231.7M,点击 Download; * 备选:MySQL Installer for Windows(图形化安装程序,

By Ne0inhk
Flutter 组件 simple_cluster 的适配 鸿蒙Harmony 实战 - 驾驭轻量级集群分发架构、实现鸿蒙端多节点任务调度与高性能负载均衡方案

Flutter 组件 simple_cluster 的适配 鸿蒙Harmony 实战 - 驾驭轻量级集群分发架构、实现鸿蒙端多节点任务调度与高性能负载均衡方案

欢迎加入开源鸿蒙跨平台社区:https://openharmonycrossplatform.ZEEKLOG.net Flutter 组件 simple_cluster 的适配 鸿蒙Harmony 实战 - 驾驭轻量级集群分发架构、实现鸿蒙端多节点任务调度与高性能负载均衡方案 前言 在鸿蒙(OpenHarmony)生态迈向“万物互联、万物协同”的深水区后,单一设备孤岛式的算力模式已经无法满足复杂的工业控制、分布式协同办公以及大规模 IoT 设备管理的需求。面对需要将一个繁重的计算任务(如:海量 Hex 数据的指纹比对)分发给附近的 5 台鸿蒙平板协同处理;面对需要管理数十个传感器节点的实时状态同步。 如果依靠传统的手动 Socket 连接管理。那么不仅会导致通讯代码极其臃肿且难以维护。更会因为缺乏确定性的负载均衡(Load Balancing)与节点心跳(Heartbeat)逻辑。引发整个系统的雪崩式失效方案。 我们需要一种“逻辑集群化、操作极简化”的算力平衡艺术。

By Ne0inhk