ipylab
data:image/s3,"s3://crabby-images/e3ee5/e3ee5921ad5878eb67ddf920f6a1b521b78831ff" alt="npm"
Control JupyterLab from Python notebooks.
The goal is to provide access to most of the JupyterLab environment from Python notebooks. For example:
- Adding widgets to the main area
DockPanel
, left, right or top area - Build more advanced interfaces leveraging
SplitPanel
, Toolbar
and other Lumino widgets - Launch arbitrary commands (new terminal, change theme, open file and so on)
- Open a workspace with a specific layout
- Listen to JupyterLab signals (notebook opened, console closed) and trigger Python callbacks
Try it online
Try it in your browser with Binder:
data:image/s3,"s3://crabby-images/fbe1d/fbe1d2f89215b7589b3f89aa2112c2614f97d3b5" alt="Binder"
Or with JupyterLite:
data:image/s3,"s3://crabby-images/0ebf3/0ebf3b104afcf20b8f7ba21a2bcd457bd2d9c946" alt="JupyterLite"
Examples
Add Jupyter Widgets to the JupyterLab interface
data:image/s3,"s3://crabby-images/a7588/a75885308d49b7b0199a446b4c1fb6920fd92ab6" alt="widgets-panels"
Execute Commands
data:image/s3,"s3://crabby-images/b3de7/b3de7817e4f2e7175325f1a151e90aea4ad14989" alt="command-registry"
Custom Python Commands and Command Palette
data:image/s3,"s3://crabby-images/daaa5/daaa5841743bc6dae24364f45619d289c5533723" alt="custom-commands"
Build small applications
data:image/s3,"s3://crabby-images/88492/88492960841816995b4fa589d126ac22b2374801" alt="ipytree-example"
Compatibility with RetroLab
A subset of the features can be used in RetroLab:
data:image/s3,"s3://crabby-images/ec317/ec317b121e7ebfa4e27cc7bc681ad1438bc8c2a5" alt="retrolab-example"
Installation
You can install using pip
:
pip install ipylab
Or with mamba
/ conda
:
mamba install -c conda-forge ipylab
Running the examples locally
To try out the examples locally, the recommended way is to create a new environment with the dependencies:
conda create -n ipylab-examples -c conda-forge jupyterlab ipylab ipytree bqplot ipywidgets numpy
conda activate ipylab-examples
jupyter lab
Under the hood
ipylab
can be seen as a proxy from Python to JupyterLab over Jupyter Widgets:
data:image/s3,"s3://crabby-images/2c321/2c32162c157765c1728eacfcefbdcfd44c852876" alt="ipylab-diagram"
Development
mamba create -n ipylab -c conda-forge jupyter-packaging nodejs python -y
conda activate ipylab
python -m pip install -e ".[dev]"
jupyter labextension develop . --overwrite
jlpm && jlpm run build
Related projects
There are a couple of projects that also enable interacting with the JupyterLab environment from Python notebooks: