Pyodide is a Python distribution for the browser and Node.js based on WebAssembly
Go to file
pfebrer 74bd881129
Add `sisl` package (#4210)
Co-authored-by: pre-commit-ci[bot] <66853113+pre-commit-ci[bot]@users.noreply.github.com>
2023-10-13 20:54:27 +02:00
.circleci CI Use xcode 15.0.0 for Safari tests (#4211) 2023-10-10 16:53:39 -07:00
.github Use upstreamed autosummary and automodule directives (#4196) 2023-10-02 12:00:32 -07:00
benchmark Ruff is now compatible with Python pattern matching (#3650) 2023-03-13 22:45:06 +01:00
cpython Use hoodmane/hiwire library instead of our own implementation (#4128) 2023-09-23 18:21:19 -07:00
docs Add `sisl` package (#4210) 2023-10-13 20:54:27 +02:00
emsdk Use hoodmane/hiwire library instead of our own implementation (#4128) 2023-09-23 18:21:19 -07:00
packages Add `sisl` package (#4210) 2023-10-13 20:54:27 +02:00
pyodide-build BLD Unpin types-setuptools (#4205) 2023-10-08 17:01:02 +09:00
src NFC Minor rearrangement of types.ts (#4215) 2023-10-11 10:05:44 -07:00
tools BLD Unpin types-setuptools (#4205) 2023-10-08 17:01:02 +09: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 Improve handling of generated typescript files (#4212) 2023-10-11 08:14:42 -07:00
.gitpod.yml Upgrade to Python v3.11.3 (#3741) 2023-04-12 17:38:05 +02:00
.pre-commit-config.yaml Update pypa/build version to 1.0 (#4180) 2023-09-27 20:41:53 +09:00
.prettierignore Rename setup.py in coolprop (#4145) 2023-09-19 20:33:58 +09:00
.readthedocs.yml Switch to using sphinx-js fork (#4193) 2023-09-30 16:41:02 -07: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 Improve handling of generated typescript files (#4212) 2023-10-11 08:14:42 -07:00
Makefile.envs Add a few things to EXPORTED_RUNTIME_METHODS (#4201) 2023-10-04 14:38:39 -07: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 Revert JSPI Changes 2023-09-14 07:26:46 -07:00
environment.yml add wget to environment.yml (#4133) 2023-09-11 11:07:28 +02: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 Rename setup.py in coolprop (#4145) 2023-09-19 20:33:58 +09:00
repository-structure.md chore: more pre-commit checking (#2257) 2022-03-07 21:51:20 -08:00
requirements.txt Update pypa/build version to 1.0 (#4180) 2023-09-27 20:41:53 +09: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.