A uv tool that wraps marimo export, extracts rendered outputs from the HTML export, and injects them into the markdown export.
The result is a self-contained markdown document with embedded figures (as base64 <img> tags), tables (as GFM or HTML), and other cell outputs.
Write your marimo .py notebook — cell outputs are rendered by default:
fig, ax = plt.subplots()
ax.plot(x, np.sin(x))
figThen run:
uvx marimo-md-export notebook.py output.mdmarimo-md-export is designed to produce markdown pages for static site generators like mkdocs or zensical.
Both work identically for this purpose.
1. Add as a docs dependency:
uv add --group docs marimo-md-export2. Add a build step that converts your notebook(s) before building the site.
For example, this project uses the following just command to build the docs:
docs:
marimo-md-export examples/notebook.py docs/example.md
zensical buildThis runs marimo-md-export to produce a self-contained markdown page (with cell outputs injected), then builds the site.
uv sync # sync packages
just # run lint, typecheck, test, build docs