Python
From What is Python?:
- Python is an interpreted, interactive, object-oriented programming language. It incorporates modules, exceptions, dynamic typing, very high level dynamic data types, and classes. It supports multiple programming paradigms beyond object-oriented programming, such as procedural and functional programming. Python combines remarkable power with very clear syntax. It has interfaces to many system calls and libraries, as well as to various window systems, and is extensible in C or C++. It is also usable as an extension language for applications that need a programmable interface. Finally, Python is portable: it runs on many Unix variants including Linux and macOS, and on Windows.
Installation
Other versions
Previous and future versions of Python are available via the AUR, and may be useful for old applications that do not run on the current version, for programs intended to run on other versions, or just for curiosity:
- Python 3.13: python313AUR pre-release
- Python 3.11: python311AUR
- Python 3.10: python310AUR
- Python 3.9: python39AUR
- Python 3.8: python38AUR (unmaintained)
- Python 3.7: python37AUR (unmaintained)
- Python 3.6: python36AUR (unmaintained)
- Python 2.7: python2AUR (unmaintained)
Each of these packages installs a distinct binary named after the version number, e.g. python3.9 for Python 3.9, allowing multiple versions to coexist on a system. You can also use pyenv to easily install and switch between multiple versions of Python.
Extra modules/libraries for old versions of Python may be found on the AUR by searching for python<version without period>
, e.g. searching for python39
for Python 3.9 modules.
You can also download the source for any release on the https://www.python.org/downloads/ page.
Alternative implementations
The python package installs CPython, the reference implementation of Python. However, there are also other implementations available. These implementations are usually based on older versions of Python and are not fully compatible with CPython.
Implementations available on Arch Linux include:
- PyPy — A Python implementation written in Python. It has speed and memory usage advantages compared to CPython.
- Jython — An implementation of the Python language written in Java. It can be used to embed Python scripting into Java programs or use Java libraries in Python programs.
- micropython — Python for microcontrollers. It includes a small subset of the Python standard library and is optimized to run on microcontrollers and in constrained environments.
- IronPython — An implementation of the Python programming language which is tightly integrated with .NET. It can use .NET libraries and allows .NET programs to use Python libraries.
More implementations exist. Some, such Cinder, are used internally at large technology companies. Others are historically notable but are no longer maintained due to improvements in the most popular implementations.
Alternative shells
The python package includes an interactive Python shell/REPL which can be launched with the python
command. The following shells are also available:
- bpython — A fancy interface for the Python interpreter.
- IPython — A powerful interactive Python shell.
- Jupyter — A web-based computation application powered by IPython.
- ptpython — An advanced Python REPL built with prompt-toolkit.
Package management
There are several ways to install Python packages on Arch Linux.
Arch Repositories
A large number of popular packages are available in the Official repositories and AUR. This is the preferred way to install system-wide packages, and the only method officially supported on Arch Linux.
Third Party Packages
Developers working with Python may need to use packages or package versions not available in the Arch repositories. The recommended practice is to use a separate virtual environment to isolate each project, preventing conflicts with system packages in /usr
. Various tools are available to install packages within a virtual environment:
- pip(1) — The official package installer for Python.
- pipx — A specialized package installer that can only be used to install packages with CLI entrypoints (but not library packages).
- Poetry — Python dependency management and packaging made easy. Poetry is a single tool to develop, build, publish, and track dependencies for Python projects.
- Conda — Conda provides package, dependency, and environment management for any language. Conda was originally created for Python, and is popular for scientific computing, data science and machine learning.
- https://docs.conda.io || python-condaAUR, anacondaAUR
- Miniconda — A miniature installation of Anaconda that includes only conda and a small number of other useful packages (excluding scientific computing packages by default).
- uv — An extremely fast Python package installer and resolver, written in Rust. Designed as a drop-in replacement for common pip and pip-tools workflows.
pip, pipx, poetry and uv install packages from the Python Package Index and other indexes. Conda and Miniconda use the Anaconda repositories.
As an alternative to virtual environments, pip install --user
can be used to install packages into the user scheme instead of /usr
. This separates packages per-user rather than per-project. Virtual environments are usually the better choice.
See the Python Packaging User Guide for the official best practices for package management.
Historical Notes
Historically, easy_install (part of python-setuptools) was used to install packages distributed as Eggs. easy_install and Eggs have been replaced with pip and Wheels. See pip vs easy_install and Package Formats for more information.
Previous versions of pip could install third-party packages system-wide, but this caused a number of problems outlined in PEP668. The system-wide environment is now marked as an externally managed environment, and pip no longer allows system-wide installation.
Widget bindings
The following widget toolkit bindings are available:
- Tkinter — The standard Python interface to the Tk GUI toolkit.
- Qt for Python (PySide2) — The official Python bindings for Qt5.
- Qt for Python (PySide6) — The official Python bindings for Qt6.
- pyQt — A set of Python bindings for Qt.
- PyGObject — Python bindings for GObject based libraries such as GTK, GStreamer, WebKitGTK, GLib, and GIO.
- wxPython — A cross-platform GUI toolkit for Python which wraps wxWidgets.
To use these with Python, you may also need to install the associated widget toolkit packages (e.g. tk must also be installed to use Tkinter).
Tips and tricks
Virtual environment
Python provides tools to create isolated virtual environments into which packages may be installed without conflicting with other virtual environments or the system packages. Virtual environments can also run applications with different versions of Python on the same system.
See Python/Virtual environment for details.
Tab completion in Python shell
Tab completion is available in the interactive shell by default. Note that the readline completer will only complete names in the global namespace. You can use python-jedi for a richer tab completion experience [1].
List packages built for a specific Python version
Sometimes it is useful to know which installed packages were built for a specific version of Python. For example,
$ pacman -Qoq /usr/lib/python3.11
will list all those built for Python version 3.11. This is especially useful when the official Python version is updated and one wants to get a list of packages from the AUR that need rebuilding because they were built for a possibly no longer installed Python version, see #Module not found after Python version update.
Troubleshooting
Module not found after Python version update
A Python-based application might output No module named module_name
for an installed dependency named module_name
after having upgraded the python package to a new minor version (e.g. from version 3.10 to 3.11).
The above scenario happens when a dependency is not available for that Python version or not installed at all. Python packages are installed in a versioned site-packages directory (/usr/lib/pythonX.Y/site-packages
if system-wide, or ~/.local/lib/pythonX.Y/site-packages/
if per-user, where X.Y
is a version like "3.11"). So whenever there is a new minor version upgrade, the Python-based package built with previous Python version must be rebuilt against the new one in order to be properly used.
Please notice it is the user's responsibility to rebuild non-official packages, including Python-based packages installed from AUR. See AUR#Updating packages and FAQ#What if I run a full system upgrade and there will be an update for a shared library, but not for the applications that depend on it?
See also
Official
- Official Python documentation (Can be installed with the python-docs package for offline access.)
- Official Python tutorial
Third-Party
- Automate the Boring Stuff with Python - Creative Commons book
- Awesome Python - A curated list of Python resources
- A Byte of Python - Creative Commons book
- Cracking Codes With Python - Free online book
- Crash into Python - Free tutorial
-
Python Debugging With Pdb - Guide to using
pdb
, the Python debugger - Dive Into Python - Creative Commons book
- Fluent Python - Commercial book
- Introducing Python - Commercial book
- Invent Your Own Computer Games with Python - Free online book
- Learn Python - Free interactive tutorial
- Learn Python the Hard Way - Commercial book
- Pythonspot Python Tutorials - Free online tutorials
- Think Python - Creative Commons book