Pyodide is a Python distribution for the browser and Node.js based on WebAssembly
Go to file
Gyeongjae Choi b41b9ea3d5
CI Split package build steps as a temporary solution for CI timeout (#4106)
2023-09-01 20:31:24 +09:00
.circleci CI Split package build steps as a temporary solution for CI timeout (#4106) 2023-09-01 20:31:24 +09:00
.github CI Disable testing in macos (#4107) 2023-08-30 16:29:47 +02:00
benchmark Ruff is now compatible with Python pattern matching (#3650) 2023-03-13 22:45:06 +01:00
cpython BLD Add CPYTHON_DEBUG environment variable to request a debug Python (#3966) 2023-06-28 17:01:15 -07:00
docs feat: add awkward-cpp v22 (#4101) 2023-08-30 16:28:59 +02:00
emsdk Emscripten 3.1.45 (#4094) 2023-08-29 13:37:31 +02:00
packages CI Split package build steps as a temporary solution for CI timeout (#4106) 2023-09-01 20:31:24 +09:00
pyodide-build Emscripten 3.1.45 (#4094) 2023-08-29 13:37:31 +02:00
src DOCS remove some private APIs from docs (#4105) 2023-08-29 14:28:52 +02:00
tools Cap cython<3 (#4001) 2023-07-18 23:47:05 -07: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.3 (#3741) 2023-04-12 17:38:05 +02:00
.pre-commit-config.yaml FIX Cap pydantic in pre-commit too 2023-07-01 09:00:33 -07:00
.prettierignore ENH Rework streams handling (#4035) 2023-08-21 08:41:44 +02: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 STY Fix typo in "geckodriver" (#3857) 2023-05-15 19:09:23 +02:00
LICENSE Initial commit 2018-02-23 14:21:29 -05:00
Makefile Emscripten 3.1.43 (#4056) 2023-08-17 15:30:32 +02:00
Makefile.envs Emscripten 3.1.45 (#4094) 2023-08-29 13:37:31 +02: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 ENH Add `loadPyodide` `packages` option for loading packages during bootstrap (#4100) 2023-08-29 13:43:07 +02: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 Use pyodide-lock for pyodide-lock.json parsing in Python (#3949) 2023-06-29 16:45:06 +00:00
repository-structure.md chore: more pre-commit checking (#2257) 2022-03-07 21:51:20 -08:00
requirements.txt pytest-pyodide 0.52.2 (#3939) 2023-06-18 20:23:06 -07:00
run_docker Update node in docker image from v14 to v20 (#3819) 2023-05-06 15:27:43 -07: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.