Skip to main content

A Qt for Python extension for Voila

Project description

QtVoila

PyPI version

A Qt for Python extension for Voila!

QtVoila a Qt for Python (PySide6) widget that controls and renders a Voila application. It's a convenient way of embedding the awesomeness of Voila in your Qt applications.

The idea of the widget and implementation details are described in this blog post.

Installation

$ pip install qtvoila

Usage

QtVoila should be imported and used as a PySide6 widget, anywhere inside your GUI application. Although it can be initialized with default parameters, you are able to define the parent (the PySide6 application), the temporary directory where any created notebooks will be temporarily stored, the path to an existing external notebook and the boolean option to either strip code sources on Voila rendering or not:

from qtvoila import QtVoila

voila_widget = QtVoila(
    parent=None,
    temp_dir=None,
    external_notebook=None,
    strip_sources=True
)

If creating a notebook programmatically, new cells can be added with the method add_notebook_cell(). This method accepts three arguments: code_imports is a dictionary of modules to be imported, code is the string containing the cell's code or markdown text and cell_type defines if the cell is of type code or markdown. Examples:

# Mardown cell
mtext = "#This is my title\n"
mtext += "Here goes some text. Check out this graphic:"
voila_widget.add_notebook_cell(code=mtext, cell_type='markdown')

# Code cell
imports = {
  'matplotlib': ['pyplot'],
  'numpy': [],
}
code = "%matplotlib inline\n"
code += "pyplot.plot(numpy.random.rand(10))"
voila_widget.add_notebook_cell(code_imports=imports, code=code, cell_type='code')

To run the Voila process and render the result on widget:

voila_widget.run_voila()

To clear widget and stop the background Voila process:

voila_widget.close_renderer()

Examples

Here you can find some examples on how to use QtVoila in your PySide6 application. For example, creating notebooks from user's input and rendering them:

To have your GUI importing existing notebooks and rendering them:

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

qtvoila-2.0.0.tar.gz (5.3 kB view details)

Uploaded Source

Built Distribution

qtvoila-2.0.0-py3-none-any.whl (5.5 kB view details)

Uploaded Python 3

File details

Details for the file qtvoila-2.0.0.tar.gz.

File metadata

  • Download URL: qtvoila-2.0.0.tar.gz
  • Upload date:
  • Size: 5.3 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.1 CPython/3.8.13

File hashes

Hashes for qtvoila-2.0.0.tar.gz
Algorithm Hash digest
SHA256 2db5235475ff5ee5285a738e8cf9a40861c02cd3d2ba4b12baece31e93a91936
MD5 a30ee80169c2c9b260dfad4eecc943b9
BLAKE2b-256 2197a7d4c671b35c231aee75bd4b40f3bf01edf7c7179cc8af6c22e1a7602d91

See more details on using hashes here.

File details

Details for the file qtvoila-2.0.0-py3-none-any.whl.

File metadata

  • Download URL: qtvoila-2.0.0-py3-none-any.whl
  • Upload date:
  • Size: 5.5 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.1 CPython/3.8.13

File hashes

Hashes for qtvoila-2.0.0-py3-none-any.whl
Algorithm Hash digest
SHA256 c988a6757d3a0cabd0e18d3b097ca1fc5d7d6c1ade9e4490b4bcefa7d1086e62
MD5 afa43e506a143e53ae9bd5f7200b4265
BLAKE2b-256 416423966d8efc63e4a8b6c92999efbdab8000782a9957ba8975f7501aaed2ad

See more details on using hashes here.

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