Pyodide is a Python distribution for the browser and Node.js based on WebAssembly
Go to file
Hood Chatham 418813de33
MAINT Split CI build-packages step in two (#2017)
Split build packages into a step for everything up to and including numpy and a second step for numpy and its dependencies.
Intended to prevent timeouts.
2021-12-05 12:34:09 -08:00
.circleci MAINT Split CI build-packages step in two (#2017) 2021-12-05 12:34:09 -08:00
.github Update description about checklists in PR template (#1964) 2021-11-16 03:18:42 +01:00
benchmark Update path for pystone import for native benchmark (#1941) 2021-11-10 09:57:35 +01:00
cpython Remove disable-set-inheritable CPython patch (#2003) 2021-11-26 14:47:04 -08:00
docs ENH Add pyimport api that imports a Python package and returns it as a pyproxy (#1944) 2021-12-05 09:56:05 -08:00
emsdk MAINT Rearrange emsdk Makefile to do less stuff before applying patches (#1938) 2021-11-09 21:46:59 -08:00
packages PKG Add pyristent to main pyodide distribution (#2008) 2021-11-30 00:27:40 +01:00
pyodide-build MAINT Split CI build-packages step in two (#2017) 2021-12-05 12:34:09 -08:00
src ENH Add pyimport api that imports a Python package and returns it as a pyproxy (#1944) 2021-12-05 09:56:05 -08:00
tools Fix typo in micropip.install() error [skip ci] (#2004) 2021-11-27 10:57:36 +01:00
.clang-format Remove keys from .clang-format 2018-11-13 09:46:24 -05: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 Add cffi package (#1761) 2021-08-01 16:12:14 +02:00
.pre-commit-config.yaml Update prettier precommit and ci rules (#1747) 2021-07-25 08:02:33 -07:00
.prettierignore Add package config for pyodide package (#1848) 2021-09-21 08:46:44 +02:00
.readthedocs.yml Fix documentation build (#939) 2020-12-24 11:39:48 +01:00
CODE-OF-CONDUCT.md DOCS Copy edit code of conduct & replace IODIDE with Pyodide (#1432) 2021-04-06 10:14:33 -07:00
Dockerfile Replace uglifyjs with terser (#1895) 2021-10-23 11:37:05 +02:00
Dockerfile-prebuilt ENH Change to minimal build by default (#1804) 2021-09-02 22:19:23 +02:00
LICENSE Initial commit 2018-02-23 14:21:29 -05:00
Makefile MAINT use npm ci to make sure the consistent dependencies installed (#1999) 2021-11-27 20:43:31 +01:00
Makefile.envs MAINT Split CI build-packages step in two (#2017) 2021-12-05 12:34:09 -08:00
README.md DOC Improve the documentation home page (#1958) 2021-11-15 10:30:59 +01:00
conftest.py ENH Add pyimport api that imports a Python package and returns it as a pyproxy (#1944) 2021-12-05 09:56:05 -08:00
lgtm.yml Apply lints suggested by lgtm.com (#1398) 2021-03-31 21:11:41 +02:00
pyodide_env.sh BLD Use outer ccache wrapper (#1805) 2021-09-11 14:22:13 +02:00
repository-structure.md DOC Replace "Javascript" with "JavaScript" in documents and comments [skip ci] (#1860) 2021-09-29 10:01:53 +02:00
requirements.txt Set up pytest node tests (#1717) 2021-07-20 10:48:27 +02:00
run_docker Fix run_docker to not ignore PYODIDE_SYSTEM_PORT (#1807) 2021-08-28 09:03:24 +02:00
setup.cfg Better test discovery (#1981) 2021-11-21 18:26:33 +01:00

README.md

NPM Latest Release PyPI Latest Release Build Status Documentation Status

Python with the scientific stack, compiled to WebAssembly.

What is Pyodide?

Pyodide may be used in any context where you want to run Python inside a web browser.

Pyodide brings the Python 3.9 runtime to the browser via WebAssembly thanks to Emscripten. It builds the Python scientific stack including NumPy, Pandas, Matplotlib, SciPy, and scikit-learn. The packages directory lists over 75 packages which are currently available. In addition, it's possible to install pure Python wheels from PyPI.

Pyodide provides transparent conversion of objects between JavaScript and Python. 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.