.. image:: https://img.shields.io/pypi/pyversions/Jep.svg
:target: https://pypi.python.org/pypi/jep
.. image:: https://img.shields.io/pypi/l/Jep.svg
:target: https://pypi.python.org/pypi/jep
.. image:: https://img.shields.io/pypi/v/Jep.svg
:target: https://pypi.python.org/pypi/jep
.. image:: https://img.shields.io/badge/docs-wiki-orange.svg
:target: https://github.com/ninia/jep/wiki
.. image:: https://img.shields.io/badge/docs-javadoc-orange.svg
:target: https://ninia.github.io/jep/javadoc
Jep - Java Embedded Python
Jep embeds CPython in Java through JNI.
Some benefits of embedding CPython in a JVM:
-
Using the native Python interpreter may be much faster than
alternatives.
-
Python is mature, well supported, and well documented.
-
Access to high quality Python modules, both native CPython
extensions and Python-based.
-
Compilers and assorted Python tools are as mature as the language.
-
Python is an interpreted language, enabling scripting of established
Java code without requiring recompilation.
-
Both Java and Python are cross platform, enabling deployment to
different operating systems.
Installation
Simply run pip install --no-cache-dir --no-build-isolation jep
or download
the source and run pip install .
. Building and installing require the JDK,
Python, setuptools, and optionally numpy to be installed beforehand. The
--no-cache-dir
and --no-build-isolation
options are not strictly
required, however those settings enable Jep to make customizations for your
environment such as enabling numpy specific behavior if numpy is installed.
Dependencies
- Python >= 3.6
- Java >= 1.8
- NumPy >= 1.7 (optional)
Notable features
- Interactive Jep console much like Python's interactive console
- Supports multiple, simultaneous, mostly sandboxed sub-interpreters or shared interpreters
- Numpy support for Java primitive arrays
Help
Documentation <https://github.com/ninia/jep/wiki>
_JavaDoc <https://ninia.github.io/jep/javadoc>
_Mailing List (deprecated) <https://groups.google.com/d/forum/jep-project>
_Known Issues and Help <https://github.com/ninia/jep/issues>
_Contribution Guidelines <https://github.com/ninia/jep/blob/master/.github/CONTRIBUTING.md>
_Project Page <https://github.com/ninia/jep>
_
We welcome comments, contributions, bug reports, wiki documentation, etc.
If you need help, please first search for existing solutions online, in the
the issues, and on the wiki. If you still need help, please open a GitHub issue
and we will try and help you. Please remember to close the issue once it has
been resolved.
Jep Team