Pyodide is a Python distribution for the browser and Node.js based on WebAssembly
Go to file
Hood Chatham c8f3971120
Add buffer format string function and tests (#1411)
2021-04-02 11:03:10 -07:00
.circleci MNT Update gitter channel name + smaller executioners in CI when possible (#1388) 2021-03-30 15:27:22 +02:00
.github/workflows Docker image with prebuilt pyodide (#787) 2020-11-08 21:05:38 +01:00
benchmark Run benchmarks in alphabetical order (#1178) 2021-01-30 13:58:34 +01:00
bin Explicitly use python3 for pyodide_build 2019-01-09 20:56:46 +05:30
cpython getting bzip2,libxml,libxslt from http instead of ftp (#1400) 2021-03-31 21:04:58 -07:00
docs API Add "loadPyodide" function (#1363) 2021-04-01 00:43:46 +02:00
emsdk Update to emscripten 2.0.15 (#1312) 2021-03-10 09:13:53 +01:00
packages MAINT Faster and more reliable WebWorker tests (#1404) 2021-04-02 09:07:25 +02:00
pyodide_build Apply lints suggested by lgtm.com (#1398) 2021-03-31 21:11:41 +02:00
src Add buffer format string function and tests (#1411) 2021-04-02 11:03:10 -07:00
tools Shorten pytest summary table test names (from #1340) (#1346) 2021-03-22 09:16:16 +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 Use hypothesis to test string conversions between js and python (#1339) 2021-03-17 10:03:42 +01:00
.pre-commit-config.yaml Use upstream file packager instead of fork (#991) 2021-01-01 08:48:28 +01:00
.readthedocs.yml Fix documentation build (#939) 2020-12-24 11:39:48 +01:00
CODE-OF-CONDUCT.md DOC/MAINT Use MyST markdown parser in the documentation (#778) 2020-10-30 21:09:25 +01:00
Dockerfile Use hypothesis to test string conversions between js and python (#1339) 2021-03-17 10:03:42 +01:00
Dockerfile-prebuilt MAINT Reorganize src/ and tests/ folders (#786) 2020-11-09 13:28:02 +01:00
LICENSE Initial commit 2018-02-23 14:21:29 -05:00
Makefile API Add "loadPyodide" function (#1363) 2021-04-01 00:43:46 +02:00
Makefile.envs Move all configuration variables for compile into Makefile.envs (#1369) 2021-03-26 15:37:59 +01:00
README.md DOC Update readme to use documentation from 0.17.0a2 (#1417) 2021-04-02 09:41:44 +02:00
conftest.py MAINT Faster and more reliable WebWorker tests (#1404) 2021-04-02 09:07:25 +02:00
lgtm.yml Apply lints suggested by lgtm.com (#1398) 2021-03-31 21:11:41 +02:00
pyodide_env.sh Use EM_COMPILER_WRAPPER to enable ccache (#1218) 2021-02-09 12:28:37 +08:00
run_docker MAINT Set shm size to 2GB in run_docker (#1401) 2021-03-31 21:53:15 +02:00
setup.cfg Universally check for hiwire memory leaks in test suite (#1340) 2021-03-24 16:32:26 -07:00

README.md

Build Status Documentation Status

Python with the scientific stack, compiled to WebAssembly.

What is Pyodide?

Pyodide brings the Python 3.8 runtime to the browser via WebAssembly, along with 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.

While closely related to the iodide project, a tool for literate scientific computing and communication for the web, Pyodide goes beyond running in a notebook environment. To maximize the flexibility of the modern web, Pyodide may be used standalone in any context where you want to run Python inside a web browser.

Try Pyodide (no installation needed)

Try pyodide in Python REPL directly in your browser.

For further information, look through the documentation.

Getting Started

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

  • Use hosted distribution of pyodide: see using pyodide from Javascript documentation.
  • Download a pre-built version from this repository's releases page and serve its contents 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.

Contributing

Please view the contributing guide for tips on filing issues, making changes, and submitting pull requests.

License

Pyodide uses the Mozilla Public License Version 2.0. See the LICENSE file for more details.