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:

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

To install, grab the package and install the Jupyter kernel spec. We also have an optional JupyterLab extension available with an improved interface:

pip install nbsafety
python -m nbsafety.install
jupyter labextension install jupyterlab-nbsafety  # optional but highly recommended if using JupyterLab

The optional JupyterLab extension shows cells with unsafe executions (due to uses of variables with stale dependencies) as having red collapsers, and recommends cells to run (in order to refresh variables with stale dependencies) by displaying them with green collapsers.

Running

Because nbsafety is implemented as a custom Jupyter kernel, it works for both Jupyter notebooks and JupyterLab (but JupyterLab with 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:

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.

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.38.tar.gz (54.7 kB 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.38-py2.py3-none-any.whl (51.2 kB view details)

Uploaded Python 2Python 3

File details

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

File metadata

  • Download URL: nbsafety-0.0.38.tar.gz
  • Upload date:
  • Size: 54.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.1.1 pkginfo/1.5.0.1 requests/2.23.0 setuptools/46.1.3 requests-toolbelt/0.9.1 tqdm/4.46.0 CPython/3.7.7

File hashes

Hashes for nbsafety-0.0.38.tar.gz
Algorithm Hash digest
SHA256 c08184a3a24928fe5e2e5fafe47c042404608808fb5f4893c876e4f159d28f3c
MD5 2d699b6ccc4916ca20d2091cfa9a9286
BLAKE2b-256 c44d43a8390cd0acc3ca507d45e635ebe2292f40c9e8fd6c8e33e324f776f38d

See more details on using hashes here.

File details

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

File metadata

  • Download URL: nbsafety-0.0.38-py2.py3-none-any.whl
  • Upload date:
  • Size: 51.2 kB
  • Tags: Python 2, Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.1.1 pkginfo/1.5.0.1 requests/2.23.0 setuptools/46.1.3 requests-toolbelt/0.9.1 tqdm/4.46.0 CPython/3.7.7

File hashes

Hashes for nbsafety-0.0.38-py2.py3-none-any.whl
Algorithm Hash digest
SHA256 c4d331ef867771b76c2b4d8bfa2fee5e8bd6300f0db47628ca041d5fe39c4272
MD5 c738ede473547b6fb1c7fc80f7658372
BLAKE2b-256 4e9b90240057d95afd0d65ded2e862ee42ee45f2963d609789f1a80df0ae707f

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