Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/jtpio/ipylab
Control JupyterLab from Python Notebooks with Jupyter Widgets 🧪 ☢️ 🐍
https://github.com/jtpio/ipylab
jupyter jupyterlab jupyterlab-extension python widgets
Last synced: 6 days ago
JSON representation
Control JupyterLab from Python Notebooks with Jupyter Widgets 🧪 ☢️ 🐍
- Host: GitHub
- URL: https://github.com/jtpio/ipylab
- Owner: jtpio
- License: bsd-3-clause
- Created: 2019-11-15T19:52:12.000Z (over 5 years ago)
- Default Branch: main
- Last Pushed: 2024-04-06T06:39:52.000Z (11 months ago)
- Last Synced: 2024-04-14T17:24:55.781Z (10 months ago)
- Topics: jupyter, jupyterlab, jupyterlab-extension, python, widgets
- Language: TypeScript
- Homepage:
- Size: 1.91 MB
- Stars: 177
- Watchers: 8
- Forks: 13
- Open Issues: 29
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- License: LICENSE
Awesome Lists containing this project
- awesome-jupyter-resources - GitHub - 36% open · ⏱️ 25.08.2022): (JupyterLab扩展)
- best-of-jupyter - GitHub - 56% open · ⏱️ 19.11.2024): (JupyterLab Extensions)
README
# ipylab
data:image/s3,"s3://crabby-images/13354/13354bc308f8a8b3bdbb5c30e97363ea3b8b3ab5" alt="Github Actions Status"
[data:image/s3,"s3://crabby-images/0ebf3/0ebf3b104afcf20b8f7ba21a2bcd457bd2d9c946" alt="JupyterLite"](https://ipylab.readthedocs.io/en/latest/lite/lab)
[data:image/s3,"s3://crabby-images/fbe1d/fbe1d2f89215b7589b3f89aa2112c2614f97d3b5" alt="Binder"](https://mybinder.org/v2/gh/jtpio/ipylab/main?urlpath=lab/tree/examples/widgets.ipynb)
[data:image/s3,"s3://crabby-images/a7787/a77878b1630806d9187ca3142de0440fdfd807d5" alt="Conda Version"](https://anaconda.org/conda-forge/ipylab)
[data:image/s3,"s3://crabby-images/60434/604340a32533eddd3982d5a3e57f654fa32032a8" alt="pypi"](https://pypi.python.org/pypi/ipylab)
[data:image/s3,"s3://crabby-images/e3ee5/e3ee5921ad5878eb67ddf920f6a1b521b78831ff" alt="npm"](https://www.npmjs.com/package/ipylab)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"](https://mybinder.org/v2/gh/jtpio/ipylab/main?urlpath=lab/tree/examples/widgets.ipynb)
Or with [JupyterLite](https://github.com/jupyterlite/jupyterlite):
[data:image/s3,"s3://crabby-images/0ebf3/0ebf3b104afcf20b8f7ba21a2bcd457bd2d9c946" alt="JupyterLite"](https://ipylab.readthedocs.io/en/latest/lite/lab)
## 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`:
```bash
pip install ipylab
```Or with `mamba` / `conda`:
```bash
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:
```bash
# create a new conda environment
conda create -n ipylab-examples -c conda-forge jupyterlab ipylab ipytree bqplot ipywidgets numpy
conda activate ipylab-examples# start JupyterLab
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/c632c/c632c8fdcc31dadc1cbe616964d0ab3abc2d57ba" alt="ipylab-diagram"
## Development
```bash
# create a new conda environment
mamba create -n ipylab -c conda-forge jupyter-packaging nodejs python -y# activate the environment
conda activate ipylab# install the Python package
python -m pip install -e ".[dev]"# link the extension files
jupyter labextension develop . --overwrite# compile the extension
jlpm && jlpm run build
```## Related projects
There are a couple of projects that also enable interacting with the JupyterLab environment from Python notebooks:
- [wxyz](https://github.com/deathbeds/wxyz): experimental widgets (including `DockPanel`)
- [jupyterlab-sidecar](https://github.com/jupyter-widgets/jupyterlab-sidecar): add widgets to the JupyterLab right area
- [jupyterlab_commands](https://github.com/timkpaine/jupyterlab_commands): add arbitrary Python commands to the jupyterlab command palette