Skip to main content

Poetry plugin to manage Jupyter kernels

Project description

poetry-jupyter-plugin

overview

This is a really simple plugin to allow you to install your Poetry virtual environment as a Jupyter kernel. You may wish to do this to keep your dependencies locked down for reproducible notebooks, or to set up a single "data science" notebook for one-off calculations without fiddling about with installing packages globally or dealing with ipykernel directly.

getting started

Install the plugin with:

$ poetry self add poetry-jupyter-plugin

Then, from within your poetry project:

$ poetry install ipykernel -G dev
$ poetry jupyter install

Remove the kernelspec with:

$ poetry jupyter remove

configuration

By default, the installed kernel will use the name of the project and a default Poetry icon. To configure these options, add this block to your pyproject.toml:

[tool.jupyter.kernel]
name = "my-cool-kernel"
display = "My cool kernel"
icon = "/path/to/icon.png"

prior art

There are other projects in this space, notably Pathbird's [poetry-kernel]. poetry-kernel installs a single kernelspec globally which then patches the virtualenv based on the specific project folder that you're running Jupyter in. This has some pros and cons over this project.

Pros:

  1. Single kernelspec, avoiding polluting the kernelspec list with lots of specs.
  2. Easy context switching between projects.

Cons:

  1. Notebooks have to be in the same folder (or a subfolder from) as the pyproject.toml folder.
  2. Requires forwarding signals from the launcher into Jupyter, introducing a layer of complexity and is brittle to changes in Jupyter protocol/underlying OS.
  3. Implicit dependency on ipykernel, and may fail to start without it.

In contrast, this project installs one kernelspec per virtualenv and leaves it up to Jupyter to launch the kernel normally without interception. This design decision also allows multiple projects to be based out of one kernel. Additionally, the tool checks for the existence of ipykernel to make sure that the kernel can be installed properly.

who?

This was written by patrick kage.

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

poetry_jupyter_plugin-0.1.3.tar.gz (120.3 kB view details)

Uploaded Source

Built Distribution

poetry_jupyter_plugin-0.1.3-py3-none-any.whl (118.8 kB view details)

Uploaded Python 3

File details

Details for the file poetry_jupyter_plugin-0.1.3.tar.gz.

File metadata

  • Download URL: poetry_jupyter_plugin-0.1.3.tar.gz
  • Upload date:
  • Size: 120.3 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.3.2 CPython/3.10.6 Darwin/22.2.0

File hashes

Hashes for poetry_jupyter_plugin-0.1.3.tar.gz
Algorithm Hash digest
SHA256 5c47a6b0bdb0c1425967878570d5862b1c5a578317e4133462d93f965cfde74e
MD5 f93d2596d5b374043146ac82e24f881b
BLAKE2b-256 953f58e3981737d86fe91568365cce44e237e9a43f7866c6c04b91ccfaf4bed2

See more details on using hashes here.

File details

Details for the file poetry_jupyter_plugin-0.1.3-py3-none-any.whl.

File metadata

File hashes

Hashes for poetry_jupyter_plugin-0.1.3-py3-none-any.whl
Algorithm Hash digest
SHA256 5e605a78657d431691f307f1677a3f9ef5052f6f70755958c55229cf96e556fc
MD5 0f4e92995cc5c7d8d2b19c4f92d99812
BLAKE2b-256 2aa598dd5dbae5be9cd8b63b5f74e9692c0eb8d34b9c5fdedbb284d2b1800127

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