Skip to main content

A lightweight Python framework for building desktop apps.

Project description

guile

A lightweight Python framework for building desktop apps.


Philosophy

Guile started as a personal tool for building lab and research apps — the kind of quick internal dashboards, data explorers, and parameter tools that are too specific to justify a full web stack, but too interactive for a script. The goal was always to stay out of the way: write Python top to bottom, get a window with a clean interface, nothing more.

It is not trying to compete with NiceGUI, PyQt, or Dash. It is the right tool for a simple lab, company, or personal project — and deliberately nothing more.

A few specific choices that shape how guile feels:

  • No full-page refresh. When state changes, only the parts of the UI that actually changed are updated. Text stays in inputs, sliders don't jump, focus is never lost.
  • No nesting hell. Layout is written top to bottom using with blocks. with gui.card(): followed by indented widget calls reads the same way the finished UI looks.
  • No server. The app runs as a single Python process and opens a window. There is no local HTTP server, no port to bind, no browser tab to manage.

Install

pip install guile

Requires pywebview. On Windows, WebView2 ships with Windows 10/11 — nothing extra to install.


Quick start

import guile as gui

count = gui.state(0)

@gui.app("Counter", width=400, height=300)
def ui():
    with gui.col(align="center", justify="center", style="height:100vh"):
        with gui.card(gap=14):
            gui.title("Counter")
            with gui.row(gap=16, align="center", justify="center"):
                gui.button("−", variant="secondary",
                           on_click=lambda: count.update(lambda x: x - 1))
                gui.text(count, size="2xl", bold=True,
                         style="min-width:64px;text-align:center")
                gui.button("+",
                           on_click=lambda: count.update(lambda x: x + 1))

How it works

  • gui.state(value) — a reactive value; setting it re-renders the UI automatically
  • with gui.card(): / with gui.col(): / with gui.row(): — layout containers; everything indented goes inside
  • gui.button(), gui.slider(), gui.input(), gui.table() — widgets that take on_click= or return their current value
  • gui.figure(fig) — embed a matplotlib figure inline
  • gui.leaflet(center, markers=...) — embed an interactive map

Examples

File What it shows
01_counter.py State, buttons, badges
02_todo.py Lists, dynamic rendering, checkboxes
03_settings.py Sliders, selects, form layout
04_mesonet_map.py Leaflet map with markers
05_weather_explorer.py Table, date picker, file picker
06_soils_lab.py Lab data entry form
07_ks_mesonet.py Live mesonet station data
08_soil_water_retention.py Sliders driving a live chart
09_upload_weather_data.py File picker, DataFrame, table
10_canopeo.py Image analysis
11_map_draw.py Leaflet with draw tools

Dependencies

Package Purpose
pywebview Window
matplotlib Only if you use gui.figure()
numpy Only if your app uses it

Everything else is Python standard library.


Files

File Role
state.py Reactive value class
ui.py Render engine + all widgets
_app.py Window lifecycle, pywebview bridge
_template.py Embedded HTML/CSS/JS
__init__.py Public API (gui.*)

Changelog

v0.4.0 — Added tabs. Fixed datetime-local input to display in 24-hour format.

v0.3.0 — Added notify and modal widgets.

v0.2.0 — Added max_height to gui.scroll(). Fixed multiselect change event.

v0.1.0 — First release. 27 widgets.


MIT License

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

guile-0.4.3.tar.gz (47.7 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

guile-0.4.3-py3-none-any.whl (48.3 kB view details)

Uploaded Python 3

File details

Details for the file guile-0.4.3.tar.gz.

File metadata

  • Download URL: guile-0.4.3.tar.gz
  • Upload date:
  • Size: 47.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.11.15

File hashes

Hashes for guile-0.4.3.tar.gz
Algorithm Hash digest
SHA256 6361154a5d8491e9ee8fbe78e9ded2d0577de3535ece0caafba18692af7b6c04
MD5 533c26e28df66474ff0a2ed3e6acf87f
BLAKE2b-256 f89f33f044f991c9d087302339f8964114f409389041071a43c91665bda8ca88

See more details on using hashes here.

File details

Details for the file guile-0.4.3-py3-none-any.whl.

File metadata

  • Download URL: guile-0.4.3-py3-none-any.whl
  • Upload date:
  • Size: 48.3 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.11.15

File hashes

Hashes for guile-0.4.3-py3-none-any.whl
Algorithm Hash digest
SHA256 9c31b91dbcb5bfa3f619789947b1c2dc2e9a62f3cae12d5422baaf1294dd6ff4
MD5 d0fc3e1613cf2360a747dbc59e5847f3
BLAKE2b-256 dc4c81273311a7bdd322ac2b21d4e4b147a2edc369b898b48a4d1a5b458ccfbe

See more details on using hashes here.

Supported by

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