Skip to main content

Tool for parametrizing, executing, and displaying Jupyter Notebooks as reports.

Project description

Notebooker

Productionise and schedule your Jupyter Notebooks, just as interactively as you wrote them. Notebooker is a webapp which can execute and parametrise Jupyter Notebooks as soon as they have been committed to git. The results are stored in MongoDB and searchable via the web interface, essentially turning your Jupyter Notebook into a production-style web-based report in a few clicks.

CircleCI Documentation Status

Run a Jupyter notebook as a report with parameters

Screenshot of "Run A Report" dialog

Execute Jupyter notebooks either on the webservice or command line

Screenshot of Executing a notebook

View the output of notebooks as static HTML

Screenshot of some notebook results

All results are accessible from the home page

Screenshot of the Notebooker homepage

Drill down into each template's results

Screenshot of result listings

Getting started

See the documentation at https://notebooker.readthedocs.io/ for installation instructions.

Notebooker has been tested on Linux, Windows 10, and OSX; the webapp has been tested on Google Chrome.

If you want to explore an example right away, you can use docker-compose:

cd docker
docker-compose up

That will expose Notebooker at http://localhost:8080/ with the example templates.

Contributors

Notebooker has been actively maintained at Man Group since late 2018, with the original concept built by Jon Bannister. It would not have been possible without contributions from:

And these fantastic projects:

0.4.2 (2022-04-27)

  • Improvement: Prometheus metrics now record number of successes/failures which have been captured by the webapp.
  • Improvement: Unpinned nbconvert and added ipython_genutils dependency

0.4.1 (2022-03-09)

  • Improvement: The email "from" address is now fully configurable.
  • Bugfix: The default "from" email address domain is no longer non-existent.
  • Improvement: --running-timeout parameter allows customization of max allowed notebook runtime

0.4.0 (2021-12-17)

  • Improvement: The index page has been overhauled to be a lot more user-friendly, divided up by notebook template name.

0.3.2 (2021-11-10)

  • Feature: .ipynb files are now natively supported and can be used as Notebook Templates (#57)

0.3.1 (2021-10-29)

  • Improvement: index page should be a lot quicker due to storage improvements.
  • Bugfix: hide_code and generate_pdf options now work as intended with the scheduler.
  • Bugfix: Large notebooks were causing serialisation errors; now safely stored in gridfs.
  • Incompatibility: Reports run with this version onwards will not be readable by older versions of Notebooker.

0.3.0 (2021-10-05)

  • Major feature: scheduling natively within Notebooker
  • Bugfix: Newer versions of uuid now work properly with Notebooker
  • Improvement: See the version number in the Notebooker GUI and with a /core/version GET call.

0.2.1 (2021-02-11)

  • Bugfix: notebooker_execute entrypoint should now work as intended
  • Bugfix: Sanity and template regression tests should now work as intended
  • Improvement: Specifying a git repo should be a little simpler

0.2.0 (2020-12-17)

  • Code output can now be hidden from PDF and email output! Either check the box in the "Run Report" dialog or, using the cli, use the new --hide-code option.
  • Performance improvement for queries

0.1.0 (2020-11-30)

Support for database plugins and tidying up configuration to be consistent across the board.

Breaking changes

  • 3 primary entrypoints have been consolidated under one - notebooker-cli, e.g. notebooker-cli start-webapp and notebooker-cli execute-notebook. Run notebooker-cli --help for more info.
  • In config, PY_TEMPLATE_DIR has been renamed to PY_TEMPLATE_BASE_DIR
  • In config, GIT_REPO_TEMPLATE_DIR has been renamed to PY_TEMPLATE_SUBDIR

0.0.2 (2020-10-25)

Bugfixes & cleanup Docker support (#14)

0.0.1 (2020-09-04)

Initial release of Notebooker

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

notebooker-0.4.2.tar.gz (28.5 MB view details)

Uploaded Source

Built Distributions

notebooker-0.4.2-py3.7.egg (36.0 MB view details)

Uploaded Source

notebooker-0.4.2-py3.6.egg (36.0 MB view details)

Uploaded Source

notebooker-0.4.2-py2.py3-none-any.whl (36.6 MB view details)

Uploaded Python 2 Python 3

File details

Details for the file notebooker-0.4.2.tar.gz.

File metadata

  • Download URL: notebooker-0.4.2.tar.gz
  • Upload date:
  • Size: 28.5 MB
  • 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.64.0 importlib-metadata/4.2.0 keyring/23.4.1 rfc3986/1.5.0 colorama/0.4.4 CPython/3.6.15

File hashes

Hashes for notebooker-0.4.2.tar.gz
Algorithm Hash digest
SHA256 1d69a7158546c70e65c2cd690653145eb10fd9731c9702439a496b753af54e75
MD5 268246f828a5f57ac77e458e19ee407b
BLAKE2b-256 2b929af958b252b1097739ec8e4e5cc8826ae3dce4b6af028444a73d65b308d8

See more details on using hashes here.

Provenance

File details

Details for the file notebooker-0.4.2-py3.7.egg.

File metadata

  • Download URL: notebooker-0.4.2-py3.7.egg
  • Upload date:
  • Size: 36.0 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.0 CPython/3.7.13

File hashes

Hashes for notebooker-0.4.2-py3.7.egg
Algorithm Hash digest
SHA256 f092014cbffe23613f9244c348c4a510fc9d6ceec38d69b74629677f56ba3535
MD5 4dfdeb06fc60cc3dc050b12b5ed39bce
BLAKE2b-256 82cc8b9257ec16986867d04e583bf6cab6db525bfd9a369034897d7137835e85

See more details on using hashes here.

Provenance

File details

Details for the file notebooker-0.4.2-py3.6.egg.

File metadata

  • Download URL: notebooker-0.4.2-py3.6.egg
  • Upload date:
  • Size: 36.0 MB
  • 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.64.0 importlib-metadata/4.2.0 keyring/23.4.1 rfc3986/1.5.0 colorama/0.4.4 CPython/3.6.15

File hashes

Hashes for notebooker-0.4.2-py3.6.egg
Algorithm Hash digest
SHA256 cedb02cf210167732c29e0e3f74a178249129172b8d5878f1f0894be11fafeb7
MD5 ae4eac8ed913d2fcb8ab204c40c9a95b
BLAKE2b-256 a86a964224d179ecca79343cb176f53be959eb5b15d041bede5e40405f7225a7

See more details on using hashes here.

Provenance

File details

Details for the file notebooker-0.4.2-py2.py3-none-any.whl.

File metadata

  • Download URL: notebooker-0.4.2-py2.py3-none-any.whl
  • Upload date:
  • Size: 36.6 MB
  • 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.64.0 importlib-metadata/4.2.0 keyring/23.4.1 rfc3986/1.5.0 colorama/0.4.4 CPython/3.6.15

File hashes

Hashes for notebooker-0.4.2-py2.py3-none-any.whl
Algorithm Hash digest
SHA256 a5109d1bfb2457cea102b57386f3d96d8949155fee54dd7258ea61d26ee41db5
MD5 ce933a76eca970903f23a3e4bb196798
BLAKE2b-256 147b19a5cd668b96bf89f82003d1e4907b6032b829cc1007ff0b506064cba241

See more details on using hashes here.

Provenance

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