|
# Pyodide JavaScript package |
|
|
|
<a href="https://www.npmjs.com/package/pyodide"><img src="https://img.shields.io/npm/v/pyodide" alt="npm"></a> |
|
|
|
## Usage |
|
|
|
Download and extract Pyodide packages from [Github |
|
releases](https://github.com/pyodide/pyodide/releases) |
|
(`pyodide-build-*.tar.bz2`). The version of the release needs to match exactly the version of this package. |
|
|
|
Then you can load Pyodide in Node.js as follows, |
|
|
|
```js |
|
// hello_python.js |
|
const { loadPyodide } = require("pyodide"); |
|
|
|
async function hello_python() { |
|
let pyodide = await loadPyodide({ |
|
indexURL: "<pyodide artifacts folder>", |
|
}); |
|
return pyodide.runPythonAsync("1+1"); |
|
} |
|
|
|
hello_python().then((result) => { |
|
console.log("Python says that 1+1 =", result); |
|
}); |
|
``` |
|
|
|
``` |
|
$ node hello_python.js |
|
Python says that 1+1= 2 |
|
``` |
|
|
|
Or you can use the REPL. To start the Node.js REPL with support for top level |
|
await, use `node --experimental-repl-await`: |
|
|
|
``` |
|
$ node --experimental-repl-await |
|
Welcome to Node.js v18.5.0. |
|
Type ".help" for more information. |
|
> const { loadPyodide } = require("pyodide"); |
|
undefined |
|
> let pyodide = await loadPyodide(); |
|
undefined |
|
> await pyodide.runPythonAsync("1+1"); |
|
2 |
|
``` |
|
|
|
## Details |
|
|
|
The JavaScript code in this package is responsible for the following tasks: |
|
|
|
1. Defines the public [JavaScript API](https://pyodide.org/en/stable/usage/api/js-api.html) |
|
- Package loading code to allow loading of other Python packages. |
|
- Can load |
|
[micropip](https://pyodide.org/en/stable/usage/api/micropip-api.html) to |
|
bootstrap loading of pure Python wheels |
|
2. Loads the CPython interpreter and the core/pyodide emscripten application |
|
which embeds the interpreter. |
|
3. Injects the `js/pyodide` JavaScript API into `sys.modules`. This is the |
|
final runtime dependency for `core/pyodide` & `py/pyodide`, so after this step |
|
the interpreter is fully up and running. |
|
|