Skip to main content

Fearless interactivity for Jupyter notebooks.

Project description

-----------------------------------------------------

➤ nbsafety

Checked with mypy License: BSD3 Binder

About

nbsafety adds a layer of protection to computational notebooks by solving the stale dependency problem, a problem which exists due to the fact that notebooks segment execution into "cells" with implicit dependencies amongst themselves. Here's an example in action:

Step 0: modify cell 1 Step 1: rerun cell 1 Step 2: rerun cell 2 Step 3: rerun cell 3

When the first cell is rerun, the second cell now contains a reference to an updated f and is suggested for re-execution with a turquoise highlight. The third cell contains a reference to a stale y -- y is stale due to its dependency on an old value of f. As such, the third cell is marked as unsafe for re-execution with a red highlight. Once the second cell is rerun, it is now suggested to re-execute the third cell in order to refresh its stale output.

nbsafety accomplishes its magic using a combination of a runtime tracer (to build the implicit dependency graph) and a static checker (to provide warnings before running a cell), both of which are deeply aware of Python's data model. In particular, nbsafety requires minimal to no changes in user behavior, opting to get out of the way unless absolutely necessary and letting you use notebooks the way you prefer.

Install

pip install nbsafety

If using JupyterLab, we highly recommend installing the companion extension:

jupyter labextension install jupyterlab-nbsafety  # optional but highly recommended if using JupyterLab

Interface

The JupyterLab extension and bundled Jupyter notebook extension both show cells with unsafe executions (due to uses of variables with stale dependencies) as being annotated with red UI elements, and recommends cells to run (in order to refresh variables with stale dependencies) by displaying them with turquoise UI elements.

Running

Because nbsafety is implemented as a custom Jupyter kernel, it works for both Jupyter notebooks and JupyterLab (if using JupyterLab, the additional labextension is recommended). To run an nbsafety kernel, select "Python 3 (nbsafety)" from the list of notebook types in Jupyter's "New" dropdown dialogue. For JupyterLab, similarly select "Python 3 (nbsafety)" from the list of available kernels in the Launcher tab.

Jupyter Notebook Entrypoint: Jupyter Lab Entrypoint:

Troubleshooting Install

The kernel and nbextension should be installed automatically, but in case the kernel is not available as an option or the UI elements are not showing up, try running the following:

python -m nbsafety.install
jupyter nbextension install --py nbsafety --sys-prefix
jupyter nbextension enable --py nbsafety --sys-prefix

Uninstall

In addition to pip uninstall nbsafety, it is also necessary to deregister the kernel from Jupyter for a full uninstall (as well as the extension from JupyterLab, if using JupyterLab):

jupyter kernelspec uninstall nbsafety
jupyter labextension uninstall jupyterlab-nbsafety

License

Code in this project licensed under the BSD-3-Clause License.

-----------------------------------------------------

➤ Contributors

Stephen Macke Ray Gong
Stephen Macke Ray Gong

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

nbsafety-0.0.57.tar.gz (1.2 MB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

nbsafety-0.0.57-py2.py3-none-any.whl (103.2 kB view details)

Uploaded Python 2Python 3

File details

Details for the file nbsafety-0.0.57.tar.gz.

File metadata

  • Download URL: nbsafety-0.0.57.tar.gz
  • Upload date:
  • Size: 1.2 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.2.0 pkginfo/1.5.0.1 requests/2.24.0 setuptools/49.6.0 requests-toolbelt/0.9.1 tqdm/4.48.2 CPython/3.8.6

File hashes

Hashes for nbsafety-0.0.57.tar.gz
Algorithm Hash digest
SHA256 8f823af1c0c1dd7206d70d7359d591521699f5326285c13526b47fe2a194b383
MD5 cf486119e27c7093d41cc242b0e447b1
BLAKE2b-256 a9f4cdbd786d7f72f824960609ba32a498a2f0299a07835007533ef80be2fc81

See more details on using hashes here.

File details

Details for the file nbsafety-0.0.57-py2.py3-none-any.whl.

File metadata

  • Download URL: nbsafety-0.0.57-py2.py3-none-any.whl
  • Upload date:
  • Size: 103.2 kB
  • Tags: Python 2, Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.2.0 pkginfo/1.5.0.1 requests/2.24.0 setuptools/49.6.0 requests-toolbelt/0.9.1 tqdm/4.48.2 CPython/3.8.6

File hashes

Hashes for nbsafety-0.0.57-py2.py3-none-any.whl
Algorithm Hash digest
SHA256 64d017b7a615f1c72a234410f7da85eddbebff6912b9200e43b37e48aaccf80c
MD5 6e1c21de2c6e841d5aca0f95473078ac
BLAKE2b-256 19d4ecca6e17ba6eec0dca4e27f65adafd4d19e614fdd4f163df98d5f77aa4e5

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page