Skip to main content

A library for making reactive notebooks and apps

Project description

A reactive Python notebook that's reproducible, git-friendly, and deployable as scripts or apps.

Docs · Discord · Examples

marimo is a reactive notebook for Python. It allows you to rapidly experiment with data and models, code with confidence in your notebook's correctness, and productionize notebooks as pipelines or interactive web apps.

Highlights.

  • reactive: run a cell, and marimo automatically updates all affected cells and outputs
  • interactive: bind sliders, tables, plots, and more to Python — no callbacks required
  • reproducible: no hidden state, deterministic execution order
  • executable: execute as a Python script
  • shareable: deploy as an app
  • git-friendly: stored as .py files
pip install marimo && marimo tutorial intro

Jump to the quickstart for a primer on our CLI.

A reactive programming environment

A reactive programming environment. Run a cell and marimo reacts by automatically running the cells that reference its variables, giving you instant feedback as you experiment with models. Delete a cell and marimo scrubs its variables from program memory, eliminating hidden state.

Notebooks are executed in a deterministic order, based on variable references instead of cells' positions on the page. Organize your notebook to best fit the story you're telling.

Synchronized UI elements. Import marimo to use interactive elements like sliders, dropdowns, dataframe transformers, selectable plots, and more. Interact with an element and all cells that use it are automatically re-run with its latest value.

Performant runtime. marimo's runtime uses static analysis to run only those cells that need to be run. You can optionally disable expensive cells to prevent them from automatically running.

Batteries-included. marimo comes with GitHub Copilot, Black code formatting, HTML export, fast code completion, a VS Code extension, and many more quality-of-life features.

Quickstart

Installation. In a terminal, run

pip install marimo  # or conda install -c conda-forge marimo
marimo tutorial intro

Create notebooks. Create an empty notebook with

marimo edit

or create/edit a notebook with a given name with

marimo edit your_notebook.py

Run apps. Run your notebook as a web app, with Python code hidden and uneditable:

marimo run your_notebook.py

This app is deployed on marimo cloud.

Execute as scripts. marimo notebooks can be executed as scripts at the command line:

python your_notebook.py

Automatically convert Jupyter notebooks. Automatically convert Jupyter notebooks to marimo notebooks with the CLI

marimo convert your_notebook.ipynb > your_notebook.py

or use our web interface.

Tutorials. List all tutorials:

marimo tutorial --help

Learn more

Ready to learn more? Check out our docs, the examples/ folder, and our gallery.

Tutorial Inputs Plots Layout

FAQ

See the FAQ at our docs.

Contributing

We appreciate all contributions! You don't need to be an expert to help out. Please see CONTRIBUTING.md for more details on how to get started.

Questions? Reach out to us on Discord.

Community

We're building a community. Come hang out with us!

Project details


Release history Release notifications | RSS feed

Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

marimo-0.1.70.tar.gz (8.4 MB view details)

Uploaded Source

Built Distribution

marimo-0.1.70-py3-none-any.whl (8.5 MB view details)

Uploaded Python 3

File details

Details for the file marimo-0.1.70.tar.gz.

File metadata

  • Download URL: marimo-0.1.70.tar.gz
  • Upload date:
  • Size: 8.4 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.10.13

File hashes

Hashes for marimo-0.1.70.tar.gz
Algorithm Hash digest
SHA256 da247c1aebdb7b9eadc13690a2a544818cbbc109303a57461372eac21a5798d2
MD5 b1f5c7aaa5d2a4e41777e273736c7d97
BLAKE2b-256 ec7429ad4e93a1793484e75eb64ceb7b01888a3d8ae7f75a3729499a28c2ded6

See more details on using hashes here.

File details

Details for the file marimo-0.1.70-py3-none-any.whl.

File metadata

  • Download URL: marimo-0.1.70-py3-none-any.whl
  • Upload date:
  • Size: 8.5 MB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.10.13

File hashes

Hashes for marimo-0.1.70-py3-none-any.whl
Algorithm Hash digest
SHA256 97381c9d7d727550ea16d397a12cc86ffb52caaea6341e8e9cb034924b0acffc
MD5 6c76cb98f65b4e72bf3a3735c9a8063e
BLAKE2b-256 c9ac078aca7cd2678551970b2afe4366a2ea1dffc8ffced1a84923ef3f3e4540

See more details on using hashes here.

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