Pyodide is a Python distribution for the browser and Node.js based on WebAssembly
Go to file
Hood Chatham 2887a24090
Add an environment variable to mount extra directories into pyodide python command (#3742)
Helpful for build systems which place stuff in temp folders. I'm working on cibuildwheel support which needs this.
2023-04-07 20:28:36 +09:00
.circleci Deploy py-compiled build (#3701) 2023-03-29 22:54:46 +02:00
.github Deploy py-compiled build (#3701) 2023-03-29 22:54:46 +02:00
benchmark Ruff is now compatible with Python pattern matching (#3650) 2023-03-13 22:45:06 +01:00
cpython Use upstream libffi (#3629) 2023-04-01 17:32:38 -07:00
docs DOC Add missing quote in DBFLAGS (#3735) 2023-04-03 08:16:35 -07:00
emsdk Emscripten 3.1.29 (#3408) 2023-01-04 09:30:46 +09:00
packages Update rebound and reboundx (#3725) 2023-04-01 17:37:30 -07:00
pyodide-build Fix passing compression-level in `pyodide py-compile` CLI (#3727) 2023-04-03 16:08:26 +09:00
src Add an environment variable to mount extra directories into pyodide python command (#3742) 2023-04-07 20:28:36 +09:00
tools Fix content compression in the deployment script (#3716) 2023-03-30 20:48:19 +02:00
.clang-format chore: update pre-commit hooks (#2209) 2022-02-23 23:58:11 -05:00
.codecov.yml Add codecov configuration (#3067) 2022-09-05 14:30:27 +09:00
.dockerignore Docker image with prebuilt pyodide (#787) 2020-11-08 21:05:38 +01:00
.editorconfig Fix #71: Upgrade to Python 3.7 2018-09-06 10:56:33 -04:00
.gitignore Build libpyodide.a (#3335) 2023-01-26 17:22:05 -08:00
.gitpod.yml Upgrade to Python v3.11.2 (#3614) 2023-03-01 23:57:17 +01:00
.pre-commit-config.yaml Using esbuild instead of rollup (take 2) (#3720) 2023-03-31 09:30:04 +02:00
.prettierignore style: improve pre-commit (#2177) 2022-02-19 09:06:25 +01:00
.readthedocs.yml Python3.11 (#3252) 2023-01-23 19:45:59 -08:00
CODE-OF-CONDUCT.md MAINT Apply prettier to everything by default (#2095) 2022-01-10 13:47:59 -08:00
Dockerfile Upgrade to Python v3.11.2 (#3614) 2023-03-01 23:57:17 +01:00
LICENSE Initial commit 2018-02-23 14:21:29 -05:00
Makefile Using esbuild instead of rollup (take 2) (#3720) 2023-03-31 09:30:04 +02:00
Makefile.envs ENH Support SDL-based packages and add pyxel (#3508) 2023-03-30 08:18:31 +00:00
README.md DOCS Edits and updates (#2756) 2022-06-21 20:15:37 -07:00
codecov.yml Disable codecov annotations in pull requests (#3197) 2022-10-24 09:21:11 +09:00
conftest.py Remove deprecated methods (#3677) 2023-03-27 10:48:33 +09:00
environment.yml DOC using conda for building from sources (Linux & Mac OS) (#3644) 2023-03-09 13:37:25 +01:00
lgtm.yml Apply lints suggested by lgtm.com (#1398) 2021-03-31 21:11:41 +02:00
pyodide_env.sh chore: more pre-commit checking (#2257) 2022-03-07 21:51:20 -08:00
pyproject.toml Support for py-compiling folders + repodata.json update (#3700) 2023-03-28 11:28:28 +00:00
repository-structure.md chore: more pre-commit checking (#2257) 2022-03-07 21:51:20 -08:00
requirements.txt Python3.11 (#3252) 2023-01-23 19:45:59 -08:00
run_docker Python 3.11.2: Set PYODIDE_IMAGE_TAG in run_docker (#3620) 2023-03-02 02:10:53 +01:00

README.md

NPM Latest Release PyPI Latest Release Build Status Documentation Status

Pyodide is a Python distribution for the browser and Node.js based on WebAssembly.

What is Pyodide?

Pyodide is a port of CPython to WebAssembly/Emscripten.

Pyodide makes it possible to install and run Python packages in the browser with micropip. Any pure Python package with a wheel available on PyPi is supported. Many packages with C extensions have also been ported for use with Pyodide. These include many general-purpose packages such as regex, PyYAML, lxml and scientific Python packages including NumPy, pandas, SciPy, Matplotlib, and scikit-learn.

Pyodide comes with a robust Javascript ⟺ Python foreign function interface so that you can freely mix these two languages in your code with minimal friction. This includes full support for error handling, async/await, and much more.

When used inside a browser, Python has full access to the Web APIs.

Try Pyodide (no installation needed)

Try Pyodide in a REPL directly in your browser. For further information, see the documentation.

Getting Started

Pyodide offers three different ways to get started depending on your needs and technical resources. These include:

  • Use a hosted distribution of Pyodide: see the Getting Started documentation.
  • Download a version of Pyodide from the releases page and serve it with a web server.
  • Build Pyodide from source
    • Build natively with make: primarily for Linux users who want to experiment or contribute back to the project.
    • Use a Docker image: recommended for Windows and macOS users and for Linux users who prefer a Debian-based Docker image with the dependencies already installed.

History

Pyodide was created in 2018 by Michael Droettboom at Mozilla as part of the Iodide project. Iodide is an experimental web-based notebook environment for literate scientific computing and communication.

Iodide is no longer maintained. If you want to use Pyodide in an interactive client-side notebook, see Pyodide notebook environments.

Contributing

Please view the contributing guide for tips on filing issues, making changes, and submitting pull requests. Pyodide is an independent and community-driven open-source project. The decision-making process is outlined in the Project governance.

Communication

License

Pyodide uses the Mozilla Public License Version 2.0.