标签: #Python #Flet #Flutter #跨平台开发 #GUI #移动端开发


🚀 前言:为什么是 Flet?

如果你是 Python 党,你一定会有这样的痛点:
脚本写得很溜,但老板非要个“可视化界面”;或者你想把数据分析结果做成一个手机 App 给客户看。
传统的 Python GUI 库(Tkinter, Qt)在移动端几乎是废的。

Flet 的核心逻辑是:

你负责写 Python(处理数据、逻辑),Flet 负责在后台调用 Flutter 引擎画出漂亮的界面。你不需要懂 CSS 布局,也不需要配置复杂的安卓环境(开发阶段)。


🏗️ 一、 架构原理:Python 怎么指挥 Flutter?

Flet 采用的是 Server-Driven UI (服务端驱动 UI) 模式。
你的 Python 代码其实是一个“服务端”,而显示界面的窗口其实是一个“Flutter 客户端”。

工作流示意图 (Mermaid):

UI 端 (Flutter 引擎)

Python 端 (你的代码)

page.add(Text)

WebSocket / HTTP

用户点击事件

更新指令

业务逻辑

Flet Server

Flet Client (App/Web)

这种架构的好处是:极快。Python 修改属性,界面毫秒级刷新,开发体验极佳。


💻 二、 极速上手:写一个计数器 App

安装 Flet:

pip install flet

新建 main.py。你会发现,它的写法非常像 React,但是是 Python 版本的。

import flet as ft

def main(page: ft.Page):
    # 1. 设置页面基础属性
    page.title = "Flet 计数器"
    page.vertical_alignment = ft.MainAxisAlignment.CENTER
    page.theme_mode = ft.ThemeMode.LIGHT # 支持深色/浅色模式切换

    # 2. 定义状态变量
    txt_number = ft.TextField(value="0", text_align=ft.TextAlign.RIGHT, width=100)

    # 3. 定义交互逻辑
    def minus_click(e):
        txt_number.value = str(int(txt_number.value) - 1)
        page.update() # 类似 React 的 setState,通知界面刷新

    def plus_click(e):
        txt_number.value = str(int(txt_number.value) + 1)
        page.update()

    # 4. 组装 UI (搭积木)
    page.add(
        ft.Row(
            [
                ft.IconButton(ft.icons.REMOVE, on_click=minus_click),
                txt_number,
                ft.IconButton(ft.icons.ADD, on_click=plus_click),
            ],
            alignment=ft.MainAxisAlignment.CENTER,
        )
    )

# 运行应用 (默认以桌面应用方式打开)
ft.app(target=main)

运行效果:
你会看到一个原生的 Windows/Mac 窗口,界面是标准的 Material Design 风格,丝滑流畅。


📱 三、 进阶:如何变成手机 App?

Flet 不仅仅是跑在电脑上的。
要在手机上预览,只需要改一行代码:

# view=ft.AppView.WEB_BROWSER 会在浏览器打开
# 局域网预览模式:
ft.app(target=main, port=8550, view=ft.AppView.WEB_BROWSER)

真机调试步骤:

  1. 确保手机和电脑在同一 WiFi 下。
  2. 电脑运行代码。
  3. 手机浏览器访问 http://电脑IP:8550
  4. 神奇的事情发生了:你的 Python 代码变成了一个 PWA 网页应用,操作手感和原生 App 几乎没区别!
打包 APK (硬核环节)

如果你真的想把这个生成 .apk 文件安装到手机上,Flet 提供了 flet build 命令(基于 Flutter SDK)。

  1. 安装 Flutter SDK 和 Android SDK(这是唯一复杂的环境配置)。
  2. 运行打包命令:
flet build apk

  1. 喝杯咖啡,Python 代码就被编译成了可以在安卓手机安装的安装包。

📊 四、 适用场景与避坑

Flet 虽然好用,但不是万能的。

维度 适合用 Flet 不适合用 Flet
应用类型 内部工具、管理后台、数据看板、简单的 CRUD 应用 3D 游戏、极其复杂的自定义动效、高性能音视频编辑
开发效率 ⭐⭐⭐⭐⭐ (极快) ⭐⭐
包体积 较大 (包含 Python解释器+Flutter引擎) 小 (原生开发)
生态 Python 生态 (Pandas, Requests 随便用) 需要深度调用手机底层硬件 (蓝牙/NFC 支持尚不完善)

🎯 总结

Flet 是 Python 工程师拓展边界的利器。
它不需要你精通前端,只要你会写 Python 函数,就能构建出颜值得体的跨平台应用。

对于 企业内部工具个人副业项目 来说,Flet 是目前性价比最高的技术选型之一。

Next Step:
把上面的计数器代码复制下来,尝试加一个 ft.Dropdown 下拉框,做一个简单的“汇率转换器”。当你第一次在手机上点开自己写的 App 时,你会爱上这种感觉的。

Logo

开源鸿蒙跨平台开发社区汇聚开发者与厂商,共建“一次开发,多端部署”的开源生态,致力于降低跨端开发门槛,推动万物智联创新。

更多推荐