A pythonic layer on top of PyQt6 / PySide6
Project description
hide:
- navigation
PrettyQt: Pythonic layer on top of PyQt6 / PySide6
What is it?
PrettyQt is a Python package that provides a pythonic layer on top of the GUI frameworks PyQt6 / PySide6.
Main Features
- Subclasses for a large part of the Qt classes, enriched with helper and _dunder_ methods to give a feel of a native GUI library.
- more than 80 pre-defined widgets and layouts for common use cases
- more than 30 ItemModels for different data types
- more than 25 general-purpose proxy models
- 10 ItemDelegates for different purposes
- 20 different validators
- Integration with pandas / numpy.
- much, much more.
PrettyQt basically is a wrapper for the whole Qt API (either on top of PySide6 or PyQt6 bindings). Perhaps it can be seen as a small Python equivalent of the KDE framework.
A large part of the library consists of a tree of mixins, with one mixin for each Qt class. These mixins also inherit from each other and are applied to the Qt classes. That way each class gets all helper methods from all sub-mixins.
Example: The class TreeView
inherits from original Qt Class QTreeView
and gets helper methods
from TreeViewMxin
, AbstractItemViewMixin
, AbstractScrollAreaMixin
,
FrameMixin
, WidgetMixin
and ObjectMixin
.
To illustrate this, we will use some of our included models:
!!! Example "Class hierarchy example"
=== "Subclass tree"
```py
from prettyqt import itemmodels, widgets
app = widgets.app()
widget = widgets.TreeView()
model = itemmodels.SubClassTreeModel(core.AbstractItemModelMixin)
widget.set_model(model)
widget.show()
```
<figure markdown>
![Image title](images/abstractitemmodelmixin_subclasses.png)
<figcaption>AbstractitemModelMixin subclasses</figcaption>
</figure>
=== "Parentclass tree"
```py
from prettyqt import itemmodels, widgets
app = widgets.app()
widget = widgets.TreeView()
model = itemmodels.ParentClassTreeModel(widgets.TreeWidget)
widget.set_model(model)
widget.show()
```
<figure markdown>
![Image title](images/treewidget_parentclasses.png)
<figcaption>TreeWidget parent classes</figcaption>
</figure>
=== "MRO tree"
```py
from prettyqt import itemmodels, widgets
app = widgets.app()
widget = widgets.TreeView()
model = itemmodels.ParentClassTreeModel(widgets.TreeWidget, mro=True)
widget.set_model(model)
widget.show()
```
<figure markdown>
![Image title](images/treewidget_mro.png)
<figcaption>TreeWidget MRO</figcaption>
</figure>
Main objective is to make Qt feel "pythonic". Qt is originally a C++ Framework, and using it can be quite cumbersome for Python developers. (very restrictive when it comes to types, very OOP-centric, lot of enum use, snakeCase naming etc.) PrettyQt aims to improve this by:
- adding more powerful methods to the classes, which accept more types and have more options (in form of keyword arguments)
- doing type conversions for method parameters to lessen the strictness for types.
- raising Exceptions or returning
None
instead of returning-1
or invalid objects. - all enum getters/setters also work with strings. Everything typed with Literals for an excellent IDE experience. (Example: )
- adding a lot of
__dunder__
methods to the classes to make them behave like good python citizens.
The minimum supported python version is 3.10. The minimum supported Qt version is 6.5
The aim is to support the last two released Python versions as well as keeping support for the last Qt LTS release.
Covered Qt modules
{% include-markdown "module_overview.md" %}
Read more about the general API design.
Apart from the mentioned mixin tree and the corresponding classes, this library also contains a lot of custom widgets, delegates, eventfilters, validators, syntaxhighlighters, layouts, models, proxy models and much more.
Converting to PrettyQt should be very straightforward since the original behaviour of the Qt classes didnt change for the largest parts and all methods from base Qt modules are still available. (There might be a few constructors with slightly different behaviour though.)
Interested? Take a look at the documentation! (even though it totally sucks in its current state.)
Where to get it
The source code is currently hosted on GitHub at: https://github.com/phil65/PrettyQt
The latest released version are available at the Python package index.
# or PyPI
pip install prettyqt
Dependencies
from prettyqt import prettyqtmarkdown
table = prettyqtmarkdown.DependencyTable("prettyqt")
print(table)
Installation from sources
This project uses poetry for dependency management and packaging. Install this first.
In the prettyqt
directory (same one where you found this file after
cloning the git repo), execute:
poetry install
License
Contributing to prettyqt
All contributions, bug reports, bug fixes, documentation improvements, enhancements, and ideas are welcome!
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
Built Distribution
Hashes for prettyqt-1.56.2-py3-none-any.whl
Algorithm | Hash digest | |
---|---|---|
SHA256 | 77a33adf6a3fd42248c56a3c5b27c1a36fd9c72260a3e96adf0904643de6df32 |
|
MD5 | 31564977ea1d320d1172a6ab39a445cd |
|
BLAKE2b-256 | db1b12ebbbb87c0caf34e0bd20bc81131d2df469399c77e1a75c43bec4bac0e7 |