Python

Python is an interpreted, high-level, general-purpose programming language. Created by Guido van Rossum and first released in 1991, Python's design philosophy emphasizes code readability with its notable use of significant whitespace. Its language constructs and object-oriented approach aim to help programmers write clear, logical code for small and large-scale projects.

In Termux Python v3.x can be installed by executing

pkg install python

Legacy, deprecated version 2.7.x can be installed by

pkg install python2

Warning: upgrading major/minor version of Python package, for example from Python 3.8 to 3.9, will make all your currently installed modules unusable. You will need to reinstall them. However upgrading patch versions, for example from 3.8.1 to 3.8.2, is safe.

'''Due to our infrastructure limits, we do not provide older versions of packages. If you accidentally upgraded to unsuitable Python version and do not have backups to rollback, do not complain! We recommend doing backups of $PREFIX for developers and other people who rely on specific software versions.'''

Package management
After installing Python,  (  if using python2) package manager will be available. Here is a quick tutorial about its usage.

Installing a new Python module:

pip install {module name}

Uninstalling Python module:

pip uninstall {module name}

Listing installed modules:

pip list

When installing Python modules, it is highly recommended to have a package to be installed - some modules compile native extensions during their installation.

Python module installation tips and tricks
It is assumed that you have  or at least  , and  installed.

It also assumed that  is not broken and works on your device. Environment variable  is not tampered or unset. Otherwise you will need to patch modules' source code to fix all shebangs!

''Tip: help us to collect more information about installing Python modules in Termux. You can also help to keep this information up-to-date, because current instructions may eventually become obsolete.''

Advanced installation instructions
Some Python modules may not be easy to install. Here are collected information on how to get them available in your Termux.

Numpy and Scipy
Building complex software like numpy and scipy is tedious. Therefore, Termux user its-pointless (aka live_the_dream) has packaged this software and maintain a Termux APT repository with these and many other useful packages.

Before Numpy/Scipy installation, you need to subscribe to APT repository: curl -LO https://its-pointless.github.io/setup-pointless-repo.sh bash setup-pointless-repo.sh

Then you can install Numpy or Scipy like a regular Termux package: pkg install numpy pkg install scipy

OpenCV
opencv can, after https://github.com/termux/termux-packages/commit/4beb926c632fdfff9a40e8db3a15f5f3b86741bf, be installed from the package repository:

pkg install opencv-python

Tkinter
Tkinter is splitted of from the  package and can be installed by

pkg install python-tkinter

We do not provide Tkinter for Python v2.7.x.

Since Tkinter is a graphical library, it will work only if X Windows System environment is installed and running. How to do this, see page Graphical Environment.

Installing Python modules from source
Some modules may not be installable without patching. They should be installed from source code. Here is a quick how-to about installing Python modules from source code.

1. Obtain the source code. You can clone a git repository of your package: git clone https://your-package-repo-url cd ./your-package-repo or download source bundle with : pip download {module name} unzip {module name}.zip cd {module name}

2. Optionally, apply the desired changes to source code. There no universal guides on that, perform this step on your own.

3. Optionally, fix the all shebangs. This is not needed if  is installed and works correctly. find. -type f -not -path '*/\.*' -exec termux-fix-shebang "{}" \;

4. Finally install the package: python setup.py install