Textualize

    Textualize/textual

    #999 this week

    The lean application framework for Python. Build sophisticated user interfaces with a simple Python API. Run your apps in the terminal and a web browser.

    cli
    framework
    python
    rich
    terminal
    tui
    Python
    MIT
    35.6K stars
    1.2K forks
    35.6K GitHub watchers
    Updated 5/4/2026
    View on GitHub

    Backblaze Generative Media Hackathon

    Build the next generation of AI media apps with Genblaze, stored on Backblaze B2. $10,000 in prizes.

    Enter the hackathon

    Loading star history...

    Use Cases & Benefits

    • Textual is a Python framework for building sophisticated terminal and web user interfaces with a simple, modern API.
    • Key features include asynchronous support, a rich widget library, flexible layout system, command palette, and cross-platform compatibility.
    • Strengths are ease of use, maintainability with decoupled components, and ability to run apps in both terminal and browser; limitation is Python-only environment.
    • High popularity with over 30,000 stars and active development since 2021, indicating strong community adoption and ongoing improvements.
    • Ideal for developers creating cross-platform CLI and web-based TUI applications needing rich interactive interfaces with low system requirements.

    About textual

    Discord Supported Python Versions PyPI version OS support

    textual-splash

    Textual

    clock

    Build cross-platform user interfaces with a simple Python API. Run your apps in the terminal or a web browser.

    Textual's API combines modern Python with the best of developments from the web world, for a lean app development experience. De-coupled components and an advanced testing framework ensure you can maintain your app for the long-term.

    Want some more examples? See the examples directory.

    """
    An App to show the current time.
    """
    
    from datetime import datetime
    
    from textual.app import App, ComposeResult
    from textual.widgets import Digits
    
    
    class ClockApp(App):
        CSS = """
        Screen { align: center middle; }
        Digits { width: auto; }
        """
    
        def compose(self) -> ComposeResult:
            yield Digits("")
    
        def on_ready(self) -> None:
            self.update_clock()
            self.set_interval(1, self.update_clock)
    
        def update_clock(self) -> None:
            clock = datetime.now().time()
            self.query_one(Digits).update(f"{clock:%T}")
    
    
    if __name__ == "__main__":
        app = ClockApp()
        app.run()
    

    [!TIP] Textual is an asynchronous framework under the hood. Which means you can integrate your apps with async libraries — if you want to. If you don't want or need to use async, Textual won't force it on you.

    Widgets

    Textual's library of widgets covers everything from buttons, tree controls, data tables, inputs, text areas, and more… Combined with a flexible layout system, you can realize any User Interface you need.

    Predefined themes ensure your apps will look good out of the box.

    buttons

    tree

    datatables

    inputs

    listview

    textarea

    Installing

    Install Textual via pip:

    pip install textual textual-dev
    

    See getting started for details.

    Demo

    Run the following command to see a little of what Textual can do:

    python -m textual
    

    Or try the textual demo without installing (requires uv):

    uvx --python 3.12 textual-demo
    

    Dev Console

    devtools

    How do you debug an app in the terminal that is also running in the terminal?

    The textual-dev package supplies a dev console that connects to your application from another terminal. In addition to system messages and events, your logged messages and print statements will appear in the dev console.

    See the guide for other helpful tools provided by the textual-dev package.

    Command Palette

    Textual apps have a fuzzy search command palette. Hit ctrl+p to open the command palette.

    It is easy to extend the command palette with custom commands for your application.

    Command Palette

    Textual ❤️ Web

    textual-serve

    Textual apps are equally at home in the browser as they are the terminal. Any Textual app may be served with textual serve — so you can share your creations on the web. Here's how to serve the demo app:

    textual serve "python -m textual"
    

    In addition to serving your apps locally, you can serve apps with Textual Web.

    Textual Web's firewall-busting technology can serve an unlimited number of applications.

    Since Textual apps have low system requirements, you can install them anywhere Python also runs. Turning any device into a connected device. No desktop required!

    Join us on Discord

    Join the Textual developers and community on our Discord Server.

    Discover Repositories

    Search across tracked repositories by name or description