A simple and robust terminal UI library, written in Python.
Project description
A simple yet powerful TUI framework for your Python (3.7+) applications
pip3 install pytermgui
Batteries included or bare-metal. It's your choice.
pytermgui has both higher and lower level interfaces. If you're only here for the terminal APIs, ansi_interface
will be your friend.
Adapting to your needs
Here are just a couple of ways to define the same widget structure:
Using the basic class structure
# -- demo.py --
import pytermgui as ptg
demo = ptg.Window(
ptg.Label("[210 bold]Hello world!"),
ptg.Label(),
ptg.InputField(prompt="Who are you?")
ptg.Label(),
ptg.Button("Submit!")
)
Using data-pattern conversion
# -- demo.py --
import pytermgui as ptg
demo = (
ptg.Window()
+ "[210 bold]Hello world!"
+ ""
+ ptg.InputField(prompt="Who are you?")
+ ""
+ ["Submit!"]
)
Using YAML
# -- demo.yaml --
widgets:
demo:
type: Window
widgets:
- Label:
value: "[210 bold]Hello world!"
- Label: {}
- InputField:
prompt: Who are you?
- Label: {}
- Button:
label: Submit!
None of these is better than any other, it is all up to individual taste. We don't force you to do what we want, rather encourage you to morph the library around your needs.
By the way, this is what the created Window
looks like. Nifty, huh?
A powerful CLI
The cli simultaneously serves as a set of powerful tooling for TUI related work, as well as a nice usage example of the higher level part of the library. You can run ptg --getch
to get information about a keypress, ptg --size
to get the current terminal dimensions and ptg --file <file>
to interpret & run a YAML markup file inside of a window manager.
For more info, check out ptg -h
.
Fully documented
The documentation details every public name in the library, making its usage as easy as possible. For more complete projects, check out examples, or some of the projects using PTG.
Projects using pytermgui
We take pride in seeing others use the library. If you have a project you'd like us to add here, create a PR!
Project name | Project description | Demo image |
---|---|---|
sipedon |
An interactive aquarium for your terminal. | |
tracers |
Easily debug and trace attribute changes in your Python classes |
Some showcase images
Click on each image to see their source code!
A hello world program
The markup playground app
Note: Use
ptg --markapp
to try
A simple window manager demo in 13 lines of code, lifted from the docs
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
File details
Details for the file pytermgui-1.0.1.tar.gz
.
File metadata
- Download URL: pytermgui-1.0.1.tar.gz
- Upload date:
- Size: 56.2 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/3.7.1 importlib_metadata/4.8.2 pkginfo/1.8.2 requests/2.26.0 requests-toolbelt/0.9.1 tqdm/4.62.3 CPython/3.9.9
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 1445199ce1d54d82fe5d0b7a1dbafd5bbdf280c8dc60340b273dbd91a1c463ed |
|
MD5 | 31c1b39c16e5aee55de42e1d90fdcb52 |
|
BLAKE2b-256 | b1fb2f60c9fc66a79b7eb3d41c4a4586840eb71e25abe87718d3a51b634151e2 |