Markdown

marimo in Markdown!

Everything in marimo is pure Python, but sometimes, annotating your notebook in markdown can be a little cumbersome. For example, hereโ€™s the code that rendered the above title and paragraph:

```{.python.marimo}
mo.md(
    '''
    # marimo in Markdown!

    Everything in marimo is pure Python, but sometimes, annotating your notebook
    in markdown can be a little cumbersome.
    '''
)
```

with markdown notebook support for marimo, you can write and save markdown directly, and marimo will execute the necessary Python code for you behind the scenes. This allows you to focus on prose, and not formatting your text in a block string. ## Python cells in markdown

When you do need to create a Python cell in the markdown format, you can use a special code block:

```{.python.marimo}
import matplotlib.pyplot as plt
plt.plot([1, 2, 3, 4])
```

This will create the following cell:

As long as your code block contains the word python in a brace, like {.python.marimo}, or {.python note="Whatever you want"}, marimo will treat it as a Python cell. ## Exporting from Python

Do you have a notebook that you think might better be suited for a markdown notebook? You can export your notebook to markdown by running the following code:

$ marimo export md my_marimo.py > my_marimo.md

by default, marimo will extract your markdown cells, and wrap your Python cells in {.python.marimo} code blocks. Although {.python.marimo} might be more concise, this format is chosen such that code highlighting will work in your favourite IDE. ## mo tricks and tips

You can break up markdown into multiple cells by using an empty html tag <!---->: View the source of this notebook to see how this cell was created. You can still hide and disable code cells in markdown notebooks:

```{.python.marimo hide_code="true"}
import pandas as pd
pd.DataFrame({'a': [1, 2, 3], 'b': [4, 5, 6]})
```
ab
014
125
236
```{.python.marimo disabled="true"}
print("This code cell is disabled, there should be no output!")
```

Additionally, marimo knows when your code has a syntax issue:

```{.python.marimo}
print("This code cell has a syntax error"
```

and on notebook save, will annotate the cell for you:

```{.python.marimo unparseable="true"}
print("This code cell has a syntax error"
```

Limitations of the markdown format

marimoโ€™s markdown support treats markdown as just plain old markdown. This means that trying to use string interpolation (like this f"{'๐Ÿƒ' * 7}") will just give you the raw string. This is a benefit, as you can clearly delineate what values are supposed to be computed, and what values are static;

and thereโ€™s nothing stopping you from executing python to achieve the same effect,

๐Ÿƒ๐Ÿƒ๐Ÿƒ๐Ÿƒ๐Ÿƒ๐Ÿƒ๐Ÿƒ

Limitations on conversion

Whenever you try to implement a cell block like this:

```{.python.marimo}
mo.md("This is a markdown cell")
```

The markdown format will know to automatically keep this as markdown. However, some ambiguous cases canโ€™t be converted to markdown like this:

This is a markdown cell with an execution block in it
# To ambiguous to convert

Itโ€™s not likely that youโ€™ll run into this issue, but rest assured that marimo is working behind the scenes to keep your notebooks unambiguous and clean as possible. ### More limitations

Since the markdown notebook really is just markdown, you canโ€™t import from a markdown notebook cells like you can in a python notebook; but you can still give your cells a name:

```{.python.marimo name="maybe"}
# ๐ŸŽต Hey, I just met you, and this is crazy
```

you can even run a notebook:

$ marimo run my_marimo.md

the markdown format is supposed to lower the barrier for writing text heavy documents, itโ€™s not meant to be a full replacement for the python notebook format. You can always convert back to a python notebook if you need to:

$ marimo convert my_marimo.md > my_marimo.py

More?!

Be sure to checkout the markdown.py tutorial for more information on to type-set and render markdown in marimo.

Back to top