Using Leo with Jupyter Notebooks¶
The chapter discusses @jupytext, a new kind of @<file> node.
Summary
- Use - @jupytextinstead of- @cleanto manage- .ipynbfiles.
- @jupytextnodes are thin wrappers around the jupytext library.
- @jupytextnodes have the form:- @jupytext x.ipynb.
- When Leo reads an - @jupytextnode without children, Leo splits the text into Leo nodes, one cell per node.
- You can edit the - @jupytexttree as usual:
 Leo will remember those changes when you save an outline.
 Leo will restore those changes when you reopen the outline.
Creating and populating @jupytext trees¶
@jupytext nodes must have the form:
@jupytext <path>x.ipynb
The path is optional. It may be absolute or relative. As usual, Leo resolves relative paths by appending the outline’s directory.
After creating this node you can populate the @jupytext node in two ways:
- [recommended] Execute the - refresh-from-diskcommand before saving the outline. Leo will immediately populate the outline.
- [also works] Save the outline. Say “no” when Leo asks whether you want to overwrite - x.ipynb! Leo will populate- @jupytext x.ipynbwhen you reopen the outline.
Populating the outline
Populating the outline splits the incoming notebook text into child nodes, one node per Jupyter Notebook cell.
- Leo populates - @jupytextonly if the node contains no children.
- Otherwise, Leo uses the - @cleanupdate algorithm to propagate changes from- x.ipynbto the- @jupytext x.ipynbtree.
Reading @jupytext trees¶
When reading an outline, Leo populates each @jupytext x.ipynb tree as follows:
- Use the jupytext library to convert - x.ipynbto jupytext text notebook text.
- Use Leo’s - @cleanupdate algorithm to propagate all changes in the- x.ipynbfile back to the corresponding node in the- @jupytexttree.
Notes:
- Notebook text looks like Python but usually contains syntax errors, so Leo never checks notebook text for syntax errors. 
- Notebook text exists only within Leo. You never need to synchronize - x.ipynbwith- x.py!
Editing @jupytext trees¶
@jupytext nodes work just like @clean.
You can add, delete, change and reorganize child nodes like any other outline tree.
Writing @jupytext trees¶
Each time you save an outline, Leo uses the jupytext library to write each @jupytext tree back to the corresponding ipynb file.
- Leo remembers all your changes when you save an outline. 
- Leo restores those changes when you reopen that outline. 
Settings¶
Three settings control how @jupytext nodes work
@int jupytext-max-headline-length = 60
This setting sets the maximum length of child headlines.
Leo truncates long lines at word boundaries.
@string jupytext-fmt = py:percent
See https://jupytext.readthedocs.io/en/latest/config.html
@data jupyter-prefix
The default body text of this node is:
# ---
# jupyter:
#   jupytext:
#     formats: py:percent
#     text_representation:
#       extension: .py
#       format_name: percent
#       format_version: '1.3'
#       jupytext_version: 1.16.4
#   kernelspec:
#     display_name: Python 3 (ipykernel)
#     language: python
#     name: python3
# ---
# %%
Extended comments about @jupytext¶
This section contains comments by HaveF (edited by EKR) about @jupytext.
The What People are Saying about Leo page contains the full version of these remarks.
Users of Jupyter Notebooks have a love-hate relationship with .ipynb files. Notebooks make it super easy to write code and see the results, but version control systems don’t handle .json files very well. However, GitHub now offers comparison tools for .ipynb files.
That’s where the jupytext library comes in. This library converts between .ipynb files to pseudo-python .py files. These files look like Python, but they usually contain syntax errors.
Furthermore, the jupytext library isn’t limited to converting Python-based .ipynb files. The library can handle .ipynb files created with many other Jupyter kernels such as the GoNB kernel.
@jupytext integrates Leo with Jupyter notebooks. You can store your notebooks directly in Leo and use Leo’s powerful outlining capabilities to manage them. When you save, Leo converts them right back to .ipynb files. This is huge.
You can edit one notebook, save it, and boom—every notebook that shares that content is automatically updated. No fuss, no hassle. The workflow is completely flexible and you won’t find these features in any other editor.
And just to make things sweeter, Thomas Passin (another Leo contributor) added a rendering feature for jupytext files in Leo, so you can even see the rendered content directly within Leo.
Summary
Working with .ipynb files becomes a breeze with Leo.
Leo can handle any .ipynb file, regardless of the Jupyter kernel that created the file.