Pyodide is a Python distribution for the browser and Node.js based on WebAssembly
Go to file
dependabot[bot] 42d13a00ce
Bump node-fetch from 2.6.1 to 2.6.7 in /src/js (#2135)
Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com>
2022-01-25 22:19:48 +01:00
.circleci Split off webworker / node compatibility into separate file (#2129) 2022-01-24 09:52:50 -08:00
.github Fix CI Pre-build docker image not deploying on tags (#2105) 2022-01-13 09:15:53 +01:00
benchmark Update path for pystone import for native benchmark (#1941) 2021-11-10 09:57:35 +01:00
cpython Remove function pointer cast emulation (#2019) 2021-12-09 10:31:21 -08:00
docs PKG updated pyb2d version (#2117) 2022-01-24 18:03:22 +01:00
emsdk Remove function pointer cast emulation (#2019) 2021-12-09 10:31:21 -08:00
packages PKG updated pyb2d version (#2117) 2022-01-24 18:03:22 +01:00
pyodide-build Use wheels instead of file_packager (#2027) 2022-01-23 17:47:04 -08:00
src Bump node-fetch from 2.6.1 to 2.6.7 in /src/js (#2135) 2022-01-25 22:19:48 +01:00
tools Use wheels instead of file_packager (#2027) 2022-01-23 17:47:04 -08: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 Use typescript (split from #2130, doesn't fix docs) (#2133) 2022-01-25 17:43:39 +01:00
.pre-commit-config.yaml Update prettier precommit and ci rules (#1747) 2021-07-25 08:02:33 -07:00
.prettierignore MAINT Apply prettier to everything by default (#2095) 2022-01-10 13:47:59 -08:00
.readthedocs.yml Fix documentation build (#939) 2020-12-24 11:39:48 +01:00
CODE-OF-CONDUCT.md MAINT Apply prettier to everything by default (#2095) 2022-01-10 13:47:59 -08: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 Use typescript (split from #2130, doesn't fix docs) (#2133) 2022-01-25 17:43:39 +01:00
Makefile.envs Use wheels instead of file_packager (#2027) 2022-01-23 17:47:04 -08:00
README.md DOCS Fix capitalization of package names in readme [skip ci] (#2068) 2021-12-26 12:46:03 -08:00
conftest.py Use wheels instead of file_packager (#2027) 2022-01-23 17:47:04 -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 MAINT Apply prettier to everything by default (#2095) 2022-01-10 13:47:59 -08:00
requirements.txt Set up pytest node tests (#1717) 2021-07-20 10:48:27 +02:00
run_docker Version 0.19.0 (#2099) 2022-01-10 15:17:53 -08:00
setup.cfg Version 0.19.0 (#2099) 2022-01-10 15:17:53 -08: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 (throw an error in one language, catch it in the other), 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.