Pyodide is a Python distribution for the browser and Node.js based on WebAssembly
Go to file
Gyeongjae Choi fd8433a013
MAINT Refactor benchmark script (#2227)
One can select which benchmark (pystone, numpy, matplotlib, or all) to be run through command-line arguments.
We can divide each benchmark to separate CI jobs in the future if needed.
Moved pystone benchmark to benchmark directory, preventing it from being included in Pyodide release.
2022-03-02 10:11:36 -08:00
.circleci MAINT Refactor benchmark script (#2227) 2022-03-02 10:11:36 -08:00
.github CI Improve docker tagging rules (#2168) 2022-02-14 18:34:13 +01:00
benchmark MAINT Refactor benchmark script (#2227) 2022-03-02 10:11:36 -08:00
cpython Remove function pointer cast emulation (#2019) 2021-12-09 10:31:21 -08:00
docs MAINT Refactor benchmark script (#2227) 2022-03-02 10:11:36 -08:00
emsdk Support for C++ exceptions in packages (#2178) 2022-02-19 08:31:19 +01:00
packages Fix Astropy: avoid failing top level imports 2022-03-02 07:05:49 -08:00
pyodide-build Remove unneeded code from pywasmcross (#2224) 2022-02-28 20:31:29 +09:00
src MAINT Refactor benchmark script (#2227) 2022-03-02 10:11:36 -08:00
tools chore: pyupgrade 3.9+ (#2195) 2022-02-20 17:13:37 -05:00
.clang-format chore: update pre-commit hooks (#2209) 2022-02-23 23:58:11 -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
.flake8 chore: enable the rest of flake8 & bugbear (#2216) 2022-02-27 12:39:53 -05:00
.gitignore Use typescript (split from #2130, doesn't fix docs) (#2133) 2022-01-25 17:43:39 +01:00
.pre-commit-config.yaml MAINT Refactor benchmark script (#2227) 2022-03-02 10:11:36 -08:00
.prettierignore style: improve pre-commit (#2177) 2022-02-19 09:06:25 +01:00
.readthedocs.yml Fix typescript documentation (#2130) 2022-01-27 00:03:50 -08:00
CODE-OF-CONDUCT.md MAINT Apply prettier to everything by default (#2095) 2022-01-10 13:47:59 -08:00
Dockerfile Update Dockerfile to install latest browser versions (#2152) 2022-02-09 21:23:05 +09: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 Refactor benchmark script (#2227) 2022-03-02 10:11:36 -08:00
Makefile.envs Support for C++ exceptions in packages (#2178) 2022-02-19 08:31:19 +01: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 ESM import in module type webworker (#2220) 2022-03-02 00:31:41 -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
pyproject.toml tests: enabling mypy on untyped defs (#2204) 2022-02-23 17:10:53 -05:00
repository-structure.md MAINT Apply prettier to everything by default (#2095) 2022-01-10 13:47:59 -08:00
requirements.txt style: improve pre-commit (#2177) 2022-02-19 09:06:25 +01:00
run_docker CI Improve docker tagging rules (#2168) 2022-02-14 18:34:13 +01: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.