
本文详解将 Flet 构建的 Python 桌面/移动端应用(如 ft.app)通过官方工具链编译为可安装的 Android APK 的完整流程,涵盖 Flutter SDK 配置、Android 环境准备、环境变量设置及构建命令执行要点。
本文详解将 flet 构建的 python 桌面/移动端应用(如 `ft.app`)通过官方工具链编译为可安装的 android apk 的完整流程,涵盖 flutter sdk 配置、android 环境准备、环境变量设置及构建命令执行要点。
Flet 支持将 Python 编写的跨平台 UI 应用(基于 ft.app())直接打包为原生 Android APK,其底层依赖 Flutter 的构建能力。但需注意:Flet 本身不提供独立的 Android 打包器,而是调用 Flutter CLI 完成编译——因此必须预先配置完整的 Flutter + Android 开发环境。
✅ 前置依赖安装(缺一不可)
-
Flutter SDK
下载并解压 Flutter SDK(推荐 stable 渠道),例如解压至 ~/flutter。
将 flutter/bin 加入系统 PATH:# Linux/macOS(添加到 ~/.zshrc 或 ~/.bashrc) export PATH="$PATH:$HOME/flutter/bin" source ~/.zshrc
# Windows(PowerShell) $env:Path += ";C:\src\flutter\bin"
-
Android Studio(含 SDK & NDK)
- 安装 Android Studio(推荐最新稳定版)。
- 启动后通过 SDK Manager 安装以下组件:
- Android SDK Platform-Tools
- Android SDK Build-Tools(≥34.0.0)
- Android SDK Platform(推荐 Android 14 / API 34)
- Android NDK (Side by side)(推荐 25.x 或 26.x)
- CMake(≥3.22.1)
-
设置关键环境变量
# 必须设置(指向 Android SDK 根目录,非 tools 子目录) export ANDROID_HOME="$HOME/Library/Android/sdk" # macOS export ANDROID_HOME="$HOME/Android/Sdk" # Linux export ANDROID_HOME="C:\Users\YourName\AppData\Local\Android\Sdk" # Windows # 推荐追加以下路径(提升构建稳定性) export PATH="$PATH:$ANDROID_HOME/platform-tools" export PATH="$PATH:$ANDROID_HOME/tools" export PATH="$PATH:$ANDROID_HOME/emulator"
⚠️ 验证是否生效:运行 flutter doctor -v。确保所有条目(尤其是 Android toolchain 和 Android SDK)显示 ✅,无红色报错。若提示 Android licenses not accepted,执行 flutter doctor --android-licenses 并全部同意。
立即学习“Python免费学习笔记(深入)”;
? 执行 APK 构建
确保你的 Flet 项目结构规范(如含 main.py 和可选 assets/ 目录),然后在项目根目录执行:
# 构建 release 版 APK(签名版,可上架) flet build apk --org com.example.myapp --name "MyFletApp" # 构建 debug 版(快速测试,无需签名) flet build apk --debug --org com.example.myapp
- --org:必填,指定反向域名格式的包名(如 com.example.myapp),将用于生成 AndroidManifest.xml 和应用签名。
- --name:可选,设置 APK 内显示的应用名称(默认取 Python 文件名)。
- 构建成功后,APK 输出路径为:build/app/outputs/flutter-apk/app-release.apk(release)或 app-debug.apk(debug)。
? 注意事项与常见问题
- Python 代码兼容性:Flet for Android 仅支持纯 Python 逻辑(不含 C 扩展、subprocess 调用系统命令、或未打包的本地二进制依赖)。所有资源(图片、字体等)须置于 assets/ 目录,并通过 page.get_asset_url("xxx.png") 引用。
-
权限声明:如需网络、存储等权限,需手动编辑 android/app/src/main/AndroidManifest.xml,在
外添加对应 标签。 -
构建失败排查:
- Command 'flutter' not found → 检查 PATH 中 flutter/bin 是否生效;
- Failed to find platform 'android-34' → 在 Android Studio SDK Manager 中安装对应 Platform;
- NDK version is outdated → 升级 NDK 至 Flutter 推荐版本(见 flutter doctor 提示)。
完成以上步骤后,你即可获得一个标准 Android APK,可直接安装至真机或模拟器运行。Flet 的构建流程高度自动化,但环境依赖严格——一次配齐,长期复用。










