Skip to main content

Flet for Python - easily build interactive multi-platform apps in Python

Project description

Flet - quickly build interactive apps for web, desktop and mobile in Python

Flet is a rich User Interface (UI) framework to quickly build interactive web, desktop and mobile apps in Python without prior knowledge of web technologies like HTTP, HTML, CSS or JavaScript. You build UI with controls based on Flutter widgets to ensure your programs look cool and professional.

Requirements

  • Python 3.7 or above on Windows, Linux or macOS

Installation

pip install flet

Create the app

Create main.py file with the following content:

import flet as ft

def main(page: ft.Page):
    page.title = "Flet counter example"
    page.vertical_alignment = ft.MainAxisAlignment.CENTER

    txt_number = ft.TextField(value="0", text_align=ft.TextAlign.RIGHT, width=100)

    def minus_click(e):
        txt_number.value = str(int(txt_number.value) - 1)
        page.update()

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

    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(main)

Run as a desktop app

The following command will start the app in a native OS window:

flet run main.py

Sample app in a native window

Run as a web app

The following command will start the app as a web app:

flet run --web main.py

Sample app in a browser

Learn more

Visit Flet website.

Continue with Python guide to learn how to make a real app.

Browse for more Flet examples.

Join to a conversation on Flet Discord server.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

flet-0.22.0.tar.gz (2.9 MB view hashes)

Uploaded Source

Built Distributions

flet-0.22.0-py3-none-win_amd64.whl (42.2 MB view hashes)

Uploaded Python 3 Windows x86-64

flet-0.22.0-py3-none-win32.whl (42.2 MB view hashes)

Uploaded Python 3 Windows x86

flet-0.22.0-py3-none-musllinux_1_2_x86_64.whl (3.0 MB view hashes)

Uploaded Python 3 musllinux: musl 1.2+ x86-64

flet-0.22.0-py3-none-manylinux_2_17_x86_64.manylinux2014_x86_64.whl (16.6 MB view hashes)

Uploaded Python 3 manylinux: glibc 2.17+ x86-64

flet-0.22.0-py3-none-manylinux_2_17_armv7l.manylinux2014_armv7l.whl (3.0 MB view hashes)

Uploaded Python 3 manylinux: glibc 2.17+ ARMv7l

flet-0.22.0-py3-none-manylinux_2_17_aarch64.manylinux2014_aarch64.whl (16.2 MB view hashes)

Uploaded Python 3 manylinux: glibc 2.17+ ARM64

flet-0.22.0-py3-none-macosx_12_0_arm64.whl (47.9 MB view hashes)

Uploaded Python 3 macOS 12.0+ ARM64

flet-0.22.0-py3-none-macosx_10_14_x86_64.whl (47.9 MB view hashes)

Uploaded Python 3 macOS 10.14+ x86-64

flet-0.22.0-py3-none-any.whl (3.0 MB view hashes)

Uploaded Python 3

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page