Use Python libraries from Node.js
Install pymport
:
npm i pymport
Install numpy
, pandas
or whatever your favorite Python package is:
npx pympip3 install numpy
Start using from Node.js:
const { pymport, proxify } = require('pymport');
const np = proxify(pymport('numpy'));
const a = np.arange(15).reshape(3, 5);
const b = np.ones([2, 3], { dtype: np.int16 });
or
import { pymport, proxify } from 'pymport';
const np = proxify(pymport('numpy'));
const a = np.arange(15).reshape(3, 5);
const b = np.ones([2, 3], { dtype: np.int16 });
Then head to the wiki for the full documentation.
Or go for the quickstart by learning from the examples.
There is also a medium stort with a brief introduction.
pymport
is unit-tested on all combinations of:
Platforms | Versions |
---|---|
OS | Windows 2019 & 2022, Ubuntu 20.04 & 22.04, macOS 11 & 12 (x86 only) |
Node.js | 14.x, 16.x and 18.x |
Python | 3.8, 3.9, 3.10 and 3.11 |
except for the following combinations that are not supported:
-
Node.js 14.x with Python 3.11: rebuilding from source is not possible due to
node-gyp
version being too old to support Python 3.11, upgradingnpm
or using the precompiled binaries solves this issue -
Node.js 14.x/16.x on Ubuntu 22.04: rebuilding from source against the system-installed Python is not possible due to Node.js containing a built-in OpenSSL 1.1 with exported symbols while the system-provided Python is built vs OpenSSL 3.0, upgrading Node.js or using the precompiled interpreter solves this issue
-
Python 3.11.x on Windows: An upstream bug requires a specific workaround in this case #44
Although both projects provide similar functionality, they are completely unrelated with very different design goals:
pymport
goal is to allow using standard Python libraries without any modification in Node.js - it brings software such asnumpy
andpandas
to Node.jsPyodide
goal is to allow using Python code in a modified interpreter both in the browser and in Node.js - it allows scripting a web page in Python
You can check the wiki for a more detailed comparison.
The wiki has a list of some known and hard to fix issues: Known Issues
Copyright 2022-2023 Momtchil Momtchev [email protected] and contributors
Permission to use, copy, modify, and/or distribute this software for any purpose with or without fee is hereby granted, provided that the above copyright notice and this permission notice appear in all copies.
THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.