Jupyter Notebook Support¶
Jupyter notebooks can be rendered as part of the documentation build system as an alternative to markdown files. The docs site uses mkdocs-jupyter to build and render jupyter notebooks as markdown files.
Note: There are some limitations to jupyter rendering.
- Notebooks are not executed as part of the docs publishing pipeline. CI tests to ensure notebook consistency are run separately (see Testing Jupyter Notebooks).
- Notebook markdown cells don't support the full range of mkdocs-material configuration, including things like admonitions, referencing automatically-generated API documentation via mkdocstrings etc. (more here).
Example code block¶
Markdown headings can be used to create a TOC similarly to traditional mkdocs pages.
a = 1
b = 2
a + b
3
Embedded visualizations¶
We can also embed images using standard approaches to embedding graphics in notebooks.
%matplotlib inline
import matplotlib.pyplot as plt
import numpy as np
xs = np.linspace(0, 2*np.pi, 100)
plt.plot(xs, np.sin(xs))
[<matplotlib.lines.Line2D at 0x7672067fb190>]
Testing Jupyter Notebooks¶
Jupyter notebooks are run as part of the CI build suite using
nbval
. To run these tests locally, run
pytest --nbval-lax docs/
from the repository root. By default, nbval
will only check that the notebook executes successfully. To add additional
checks to ensure the consistency of the output, add a #NBVAL_CHECK_OUTPUT
marker comment, which will ensure that the
output of the saved jupyter notebook matches the output when the notebook is executed in CI.
For example:
#NBVAL_CHECK_OUTPUT
import numpy as np
print(np.arange(5))
[0 1 2 3 4]