Embed JupyterLab in PySide6 applications
Project description
jupyqt
Embed JupyterLab in PySide6 applications — no ipykernel, no ZMQ, no qasync.
Features
- Background-thread kernel — cell execution never blocks the Qt event loop
- Top-level
await— async/await works in notebook cells out of the box - Qt proxy — safely manipulate Qt widgets from notebook code
- jupyverse server — full JupyterLab UI via QWebEngineView or external browser
Installation
pip install jupyqt
With uv:
uv add jupyqt
Quick start
from PySide6.QtWidgets import QApplication, QMainWindow, QVBoxLayout, QWidget
from jupyqt import EmbeddedJupyter
app = QApplication([])
window = QMainWindow()
jupyter = EmbeddedJupyter()
jupyter.shell.push({"greeting": "Hello from jupyqt!"})
jupyter.start()
central = QWidget()
QVBoxLayout(central).addWidget(jupyter.widget())
window.setCentralWidget(central)
window.show()
app.exec()
jupyter.shutdown()
Exposing Qt objects to the notebook
Wrap Qt objects with wrap_qt() so notebook cells can safely call methods on the main thread:
jupyter.push({
"window": jupyter.wrap_qt(main_window),
"label": jupyter.wrap_qt(some_label),
"do_stuff": my_function,
})
Then in a notebook cell:
window.setWindowTitle("Controlled from Jupyter!")
label.setText("Updated from a cell")
import asyncio
for i in range(5):
await asyncio.sleep(0.5)
do_stuff()
Examples
# Minimal smoke test
uv run python examples/minimal_app.py
# Full demo with exposed UI, counter widget, and demo notebook
uv run python examples/demo_app.py
Architecture
┌─────────────────────────────────────┐
│ JupyterLabWidget (QWebEngineView) │ ← Qt main thread
└───────────────┬─────────────────────┘
│ HTTP / WebSocket
┌───────────────┴─────────────────────┐
│ jupyverse (fps + anyio) │ ← server thread
└───────────────┬─────────────────────┘
│ anyio MemoryObjectStreams
┌───────────────┴─────────────────────┐
│ Wire Protocol + InteractiveShell │ ← kernel thread (asyncio)
└───────────────┬─────────────────────┘
│ QtProxy (blocking invoke)
┌───────────────┴─────────────────────┐
│ Host Qt Application │ ← Qt main thread
└─────────────────────────────────────┘
Three threads, no shared event loop, no reentrancy.
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
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file jupyqt-0.5.2.tar.gz.
File metadata
- Download URL: jupyqt-0.5.2.tar.gz
- Upload date:
- Size: 70.6 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
9a8bee5b2fc62b6b4ccd5063ce54a1e10cbfa72074f402af121d8dc3ace0b0fa
|
|
| MD5 |
706c19acc9ca3bc1f36ad181fba52ed3
|
|
| BLAKE2b-256 |
99401aebb75f2b83ec333649b93b2a98abbfe0fe6e719ef582064cb827bddfca
|
Provenance
The following attestation bundles were made for jupyqt-0.5.2.tar.gz:
Publisher:
release.yml on SciQLop/jupyqt
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
jupyqt-0.5.2.tar.gz -
Subject digest:
9a8bee5b2fc62b6b4ccd5063ce54a1e10cbfa72074f402af121d8dc3ace0b0fa - Sigstore transparency entry: 1288105626
- Sigstore integration time:
-
Permalink:
SciQLop/jupyqt@d2f51668dc8c2384adff35c2355b4c4bdc1b8bb0 -
Branch / Tag:
refs/tags/0.5.2 - Owner: https://github.com/SciQLop
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
release.yml@d2f51668dc8c2384adff35c2355b4c4bdc1b8bb0 -
Trigger Event:
push
-
Statement type:
File details
Details for the file jupyqt-0.5.2-py3-none-any.whl.
File metadata
- Download URL: jupyqt-0.5.2-py3-none-any.whl
- Upload date:
- Size: 28.2 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
c0d59c38908607eadd62e43dcde0f032fd95261d94df5f76a7b16c7b4d2ddbfd
|
|
| MD5 |
3df1d18654b4422189a5b75012dee603
|
|
| BLAKE2b-256 |
3bc368e1d6b3348b1d5830f736daae8b20f965e4459beed5aa27b0c3b211b63b
|
Provenance
The following attestation bundles were made for jupyqt-0.5.2-py3-none-any.whl:
Publisher:
release.yml on SciQLop/jupyqt
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
jupyqt-0.5.2-py3-none-any.whl -
Subject digest:
c0d59c38908607eadd62e43dcde0f032fd95261d94df5f76a7b16c7b4d2ddbfd - Sigstore transparency entry: 1288105722
- Sigstore integration time:
-
Permalink:
SciQLop/jupyqt@d2f51668dc8c2384adff35c2355b4c4bdc1b8bb0 -
Branch / Tag:
refs/tags/0.5.2 - Owner: https://github.com/SciQLop
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
release.yml@d2f51668dc8c2384adff35c2355b4c4bdc1b8bb0 -
Trigger Event:
push
-
Statement type: