Fearless interactivity for Jupyter notebooks.
Project description
➤ nbsafety
About
nbsafety
adds a layer of protection to computational notebooks by solving the
stale dependency problem when executing cells out-of-order. Here's an
example in action:
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
Interface
The kernel ships with an extension that highlights cells with live references to stale symbols using red UI elements. It furthermore uses turquoise highlights for cells with live references to updated symbols, as well as for cells that resolve staleness.
Running
To run an nbsafety
kernel in Jupyter, 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
pip uninstall nbsafety
License
Code in this project licensed under the BSD-3-Clause License.
➤ Contributors
Stephen Macke | Ray Gong | Shreya Shankar |
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
Built Distribution
File details
Details for the file nbsafety-0.0.87.tar.gz
.
File metadata
- Download URL: nbsafety-0.0.87.tar.gz
- Upload date:
- Size: 155.5 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/3.8.0 pkginfo/1.8.2 readme-renderer/34.0 requests/2.27.1 requests-toolbelt/0.9.1 urllib3/1.26.9 tqdm/4.63.1 importlib-metadata/4.11.3 keyring/23.5.0 rfc3986/2.0.0 colorama/0.4.4 CPython/3.9.7
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 4203067e5a5adf6601c60030185e442623478813bbbfbe6b6f61daeee76da2b3 |
|
MD5 | 4aacb1d559edd360891c3b2ba6fbd915 |
|
BLAKE2b-256 | 350d84166f0506ac7bcd5825814f950ce0788d0bcb204f5186d692bde6ab1300 |
File details
Details for the file nbsafety-0.0.87-py2.py3-none-any.whl
.
File metadata
- Download URL: nbsafety-0.0.87-py2.py3-none-any.whl
- Upload date:
- Size: 157.8 kB
- Tags: Python 2, Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/3.8.0 pkginfo/1.8.2 readme-renderer/34.0 requests/2.27.1 requests-toolbelt/0.9.1 urllib3/1.26.9 tqdm/4.63.1 importlib-metadata/4.11.3 keyring/23.5.0 rfc3986/2.0.0 colorama/0.4.4 CPython/3.9.7
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | f204ea8c56035d721bcf43d58bc6ef6618af4080a420d559d127a8a52c0bab19 |
|
MD5 | 2e005c0dc884f4db9617ec1c5b4f7997 |
|
BLAKE2b-256 | 4d30dcbc3bdd778fae08f6f1916074838e2085142bcd9dc589f27bad68768345 |