PyApp:一种将 Python 工程打包为可执行文件的简易方法

PyApp:一种将 Python 工程打包为可执行文件的简易方法

PyApp 工具以 Rust 语言编写,可将 Python 程序封装为独立的“点击即运行”可执行文件。它或许是目前最易用的 Python 打包工具。

每个开发者都知道,要把一个 Python 程序重新分发为独立的、点击即运行的软件包是多么困难。虽然市面上有第三方解决方案,但它们都存在各种缺点。

  • PyInstaller:这是历史最悠久、也最知名的工具,但使用起来颇为棘手,往往需要大量的试错才能生成一个可用的分发包。
  • Nuitka:这是一个较新的项目,它将 Python 程序编译为可分发的二进制文件,但生成的产物体积可能非常庞大,且编译耗时很长。

而一个名为 PyApp 的新项目,采取了一种截然不同的方法。它是一个 Rust 程序,你需要结合想要分发的 Python 项目信息,从源代码进行编译。生成的结果是一个独立的二进制文件,运行时会将你的项目解压到一个目录中并从中执行。最终用户无需在他们的系统上安装 Python 即可使用它。

搭建 PyApp 环境

与其他 Python 分发解决方案不同,PyApp 既不是像 PyInstaller 那样的 Python 库,也不是一个直接接收你的程序并生成产物的独立程序。相反,你需要为每一个想要分发的 Python 程序,定制化构建一个专属的 PyApp。

在使用 PyApp 部署 Python 程序之前,你需要先搞定以下几个先决条件:

  1. PyApp 的源代码:克隆一份 PyApp 的源码,并将其放在一个独立的目录中,与其他项目隔离开。
  2. Rust 编译器及相关环境:如果你不熟悉 Rust 或其工具链,至少需要掌握如何从源代码编译一个 Rust 程序的基础知识。
  3. 打包为 Wheel 格式的 Python 程序:“Wheel”(即 .whl 文件)是用于打包 Python 程序及其平台特定组件(如预编译库)的二进制格式。如果你还没有目标程序的 wheel 包,就需要生成一个。你也可以直接使用托管在 PyPI 上的 wheel 包。

配置环境变量

PyApp 在构建过程中会读取环境变量,以确定你要编译哪个 Python 项目以及如何支持它。以下是最常用的变量:

  • PYAPP_PROJECT_NAME:定义你要打包的 Python 项目的名称。如果你使用 pyproject.toml 定义项目,它应与 project.name 属性匹配。这也可以是 PyPI 上某个项目的名称;如果不是,你就需要定义所用 .whl 文件的路径。
  • PYAPP_PROJECT_VERSION:如果需要,用它来配置项目的特定版本。
  • PYAPP_PROJECT_PATH:指向你的项目 .whl 文件的路径(相对或绝对路径)。如果你只是从 PyPI 安装 wheel 包,则可省略此变量。
  • PYAPP_EXEC_MODULE:许多 Python 包可以通过模块形式直接运行。此变量用于声明要使用的模块。例如,如果你的程序通过 python -m thisprogram 运行,就将此变量设为 thisprogram
  • PYAPP_EXEC_SPEC:针对具有入口点脚本的程序,你可以在这里指定。它对应 pyproject.toml 中 project.scripts 部分的语法。例如,pyprogram.cmd:main 会导入你程序模块中的 pyprogram.cmd,然后执行其中的 main() 函数。
  • PYAPP_EXEC_SCRIPT:此变量允许你提供一个任意 Python 脚本的路径,该脚本会被嵌入二进制文件并在启动时执行。
  • PYAPP_DISTRIBUTION_EMBED:通常情况下,当你创建 PyApp 二进制文件时,它会在首次执行时从互联网下载运行所需的 Python 发行版。如果将此变量设为 1,PyApp 会将所需的 Python 发行版预先打包进生成的二进制文件中。结果是生成的文件体积更大,但它无需下载任何内容,可以直接解压并运行。

虽然还有许多其他选项可用,但对于大多数项目而言,以上这些已经足够了。

为了方便自己,你可以为每个项目创建一个 shell 脚本,用于设置这些环境变量并运行编译过程。

构建 PyApp 二进制文件

设置好环境变量后,进入 PyApp 源码的根目录,使用 Rust 编译器运行以下命令来构建 PyApp:

cargo build --release 

这可能需要花费几分钟时间,因为 PyApp 的依赖项相当多。不过,等到 Rust 获取并缓存了所有依赖后,后续的编译过程就会快得多。

请注意:虽然理论上可以进行跨平台编译(即在一种平台上编译出适用于其他平台的程序),但这并不被推荐,也不受官方支持。

编译完成后,生成的二进制文件会位于 PyApp 项目目录下的 target/release 子文件夹中,文件名为 pyapp.exe。你可以根据需要随意重命名该文件,只要保持其可执行文件的属性即可。

运行 PyApp 二进制文件

要测试该二进制文件,只需在控制台中直接运行它。如果一切正常,你应该能看到控制台中出现提示信息,显示 PyApp 正在自我解压并准备运行。如果在控制台中看到任何报错信息,请留意这些提示并检查你的环境变量设置;很有可能是项目的入口点或启动脚本没有正确配置。

当 PyApp 二进制文件首次运行时,它会将自己解压到一个目录中,该目录通常位于用户配置文件的子目录下。在后续的运行中,它会直接使用那个已经解压好的副本,因此启动速度会快得多。

如果你希望控制二进制文件的解压位置,可以通过设置环境变量来指定程序运行时读写及查找其解压内容的目录:

PYAPP_INSTALL_DIR_<project_name> = "path/to/directory"

请注意,<project_name> 是 PYAPP_PROJECT_NAME 变量的大写版本。因此,对于名为 conwaylife 的程序,我们使用的变量名应为 PYAPP_INSTALL_DIR_CONWAYLIFE。该目录可以是绝对路径,也可以是相对路径,例如你可以使用 ./app 这样的目录,表示将程序解压到当前工作目录下的 app 子文件夹中。

另外请注意,此设置并非持久化的。如果你在运行程序时没有设置这个确切的环境变量,程序将默认解压到用户配置文件目录下。

PyApp 选项

部署好的 PyApp 可执行文件内置了几个方便的命令:

  • pyapp self remove:从解压目录中移除已解压的应用程序。
  • pyapp self restore:移除并重新安装应用程序。

再次提醒,如果你使用了 PYAPP_INSTALL_DIR_ 变量来指定项目存放位置,那么在运行上述命令时,也必须设置该环境变量!

此外,还有一点很重要:在 Microsoft Windows 系统上,PyApp 打包的应用程序可能会被杀毒软件误报(产生“假阳性”),因为生成的可执行文件默认没有进行代码签名。

Read more

实测|龙虾机器人(OpenClaw)Windows系统部署全攻略(含避坑指南)

作为一名热衷于折腾新技术的ZEEKLOG博主,最近被一款名为「龙虾机器人」的开源AI工具圈粉了!它还有个更正式的名字——OpenClaw(曾用名Clawdbot、MoltBot),不同于普通的对话式AI,这款工具能真正落地执行任务,比如操作系统命令、管理文件、对接聊天软件、自动化办公,而且支持本地部署,数据隐私性拉满。 不过调研发现,很多小伙伴反馈龙虾机器人在Windows系统上部署容易踩坑,官方文档对Windows的适配细节描述不够细致。今天就结合自己的实测经历,从环境准备、分步部署、初始化配置,到常见问题排查,写一篇保姆级攻略,不管是新手还是有一定技术基础的同学,都能跟着一步步完成部署,少走弯路~ 先简单科普下:龙虾机器人本质是一款开源AI代理框架,核心优势是“能行动、可本地、高灵活”——它不内置大模型,需要对接第三方AI接口(如GPT、Claude、阿里云百炼等),但能将AI的指令转化为实际的系统操作,相当于给AI配了一个“能动手的身体”,这也是它和普通对话大模型的核心区别。另外要注意,它还有一种“生物混合龙虾机器人”的概念,是利用龙虾壳改造的柔性机器人,本文重点分享的是可本

By Ne0inhk
在ESP32-S3部署mimiclaw,基于deepseek并用飞书机器人开展对话-feishu

在ESP32-S3部署mimiclaw,基于deepseek并用飞书机器人开展对话-feishu

最近mimiclaw火爆,其开发团队也在密集更新,我看3天前已经可以用“飞书机器人”对话交互了。 目前网络上能查到的部署资料相对滞后,现在将飞书机器人的部署整理如下: 1. 前提 已经安装好ESP-IDF,并支持vscode编译esp32固件。 2. api-key准备 * 注册deepseek, * 创建APIkey, * 并充值,新注册的用户余额为零,无法使用 3. 飞书机器人 我是在飞书个人版中,创建的机器人。 1. 访问飞书开放平台,单击创建企业自建应用,填写应用名称和描述,选择应用图标,单击创建。 2. 左侧导航栏单击凭证与基础信息 页面,复制App ID(格式如 cli_xxx)和App Secret。 3. 配置事件订阅。 1. 在飞书开放平台左侧导航栏单击事件与回调,在事件配置页签中单击订阅方式,选择使用 长连接 接收事件,单击保存。 2. 在事件配置页面,单击添加事件,

By Ne0inhk
AirSim无人机仿真入门(一):实现无人机的起飞与降落

AirSim无人机仿真入门(一):实现无人机的起飞与降落

概述: 安装好所需要的软件和环境,通过python代码控制无人机进行起飞和降落。 参考资料: 1、知乎宁子安大佬的AirSim教程(文字教程,方便复制) 2、B站瑜瑾玉大佬的30天RL无人机仿真教程(视频教程,方便理解) 3、AirSim官方手册(资料很全,不过是纯英文的) AirSim无人机仿真入门(一):实现无人机的起飞与降落 * 1 安装AirSim * 1.1 参考教程 * 1.2 内容梳理 * 1.3 步骤总结 * 2 开始使用 AirSim * 2.1 参考教程 * 2.2 内容梳理 * 2.3 步骤总结 * 3 撰写python控制程序 * 3.1 参考教程 * 3.2 内容梳理

By Ne0inhk
HarmonyOS6 底部导航栏组件 rc_concave_tabbar 使用指南

HarmonyOS6 底部导航栏组件 rc_concave_tabbar 使用指南

文章目录 * 前言 * 组件特性 * 适用场景 * 使用说明 * 安装组件 * 安装步骤 * 步骤一:引入相关依赖 * 步骤二:创建菜单数据 * 步骤三:使用导航组件 * 运行效果 * 参数介绍 * TabsConcaveCircle 组件参数 * TabMenusInterfaceIRequired 菜单项配置 * 进阶使用 * 自定义单个菜单项颜色 * 调整动画速度 * 自定义高度和颜色 * 注意事项 * 总结 前言 rc_concave_tabbar 是一个功能强大、样式精美的 HarmonyOS 底部导航栏组件库,提供凹陷圆形动画效果样式,适用于多种场景。本篇将介绍 rc_concave_tabbar 的使用方法以及其相关的设计理念。 组件特性 * 流畅动画:支持流畅的凹陷圆形切换动画效果 * 高度定制:支持自定义背景色、字体颜色、高度等多种样式配置 * 灵活配置:支持全局配置和单项配置,满足不同场景需求

By Ne0inhk