pip (1) - Linux Manuals
pip: A tool for installing and managing Python packages
NAME
pip - A tool for installing and managing Python packages
SYNOPSIS
pip <command> [options]
DESCRIPTION
pip is a Python package installer, recommended for installing Python packages which are not available in the Debian archive. It can work with version control repositories (currently only Git, Mercurial, and Bazaar repositories), logs output extensively, and prevents partial installs by downloading all requirements before starting installation.
On Debian, pip is the command to use when installing packages for Python 2, while pip3 is the command to use when installing packages for Python 3.
COMMANDS
The command comes before any options. The following commands are recognized:
- help
- Show help for commands.
- install
- Install packages.
- uninstall
- Uninstall packages.
- freeze
- Output installed packages in requirements format.
- list
- List installed packages.
- show
- Show information about installed packages.
- search
- Search PyPI for packages.
- wheel
- Build wheels from your requirements.
GENERAL OPTIONS
This list is by no means complete, and it only describes options available to all commands. Use pip <command> --help for more details on command specific options. A few command options are provided below.
- -h, --help
- Show more detailed command help.
- -v, --verbose
- Give more output. Option is additive, and can be used up to 3 times.
- -V, --version
- Show version and exit.
- -q, --quiet
- Give less output.
- --log-file <path>
- Path to a verbose non-appending log, that only logs failures. This log is active by default at ~/.pip/pip.log.
- --log <path>
- Path to a verbose appending log. This log is inactive by default.
- --proxy <proxy>
- Specify a proxy in the form [user:passwd@]proxy.server:port.
- --timeout <sec>
- Set the socket timeout (default 15 seconds).
- --exists-action <action>
- Default action when a path already exists: (s)witch, (i)gnore, (w)ipe, (b)ackup.
- --cert <path>
- Path to alternate CA bundle.
INSTALL OPTIONS
pip install installs packages from:
- •
- PyPI (a.k.a. The Cheeseshop) and other indexes, using requirements specifiers.
- •
- VCS project urls.
- •
- Local project directories.
- •
- Local or remote source archives
- •
- Local wheel directories (python-pip-whl installs its wheels in /usr/share/ python-wheels and they can be locally installed by pip using --find-links)
- -e,--editable <path/url>
- Install a project in editable mode (i.e. setuptools "develop mode") from a local project path or a VCS url.
- -r,--requirement <file>
- Install from the given requirements file. This option can be used multiple times.
- -b,--build <dir>
- Directory to unpack packages into and build in. The default in a virtualenv is "<venv path>/build". The default for global installs is "<OS temp dir>/pip_build_<username>".
- -t,--target <dir>
- Install packages into <dir>.
- -d,--download <dir>
- Download packages into <dir> instead of installing them, regardless of what's already installed.
- --download-cache <dir>
- Cache downloaded packages in <dir>.
- --src <dir>
- Directory to check out editable projects into. The default in a virtualenv is "<venv path>/src". The default for global installs is "<current dir>/src".
- -U, --upgrade
- Upgrade all packages to the newest available version. This process is recursive regardless of whether a dependency is already satisfied.
- --force-reinstall
- When upgrading, reinstall all packages even if they are already up-to-date.
- -I, --ignore-installed
- Ignore the installed packages (reinstalling instead).
- --no-deps
- Don't install package dependencies.
- --install-option <options>
- Extra arguments to be supplied to the setup.py install command (use like --install-option ="--install-scripts=/usr/local/bin"). Use multiple --install-option options to pass multiple options to setup.py install. If you are using an option with a directory path, be sure to use absolute path.
- --global-option <options>
- Extra global options to be supplied to the setup.py call before the install command.
- --user
- Install using the user scheme.
- --egg
- Install packages as eggs, not 'flat', like pip normally does. This option is not about installing from eggs. (WARNING: Because this option overrides pip's normal install logic, requirements files may not behave as expected.)
- --root <dir>
- Install everything relative to this alternate root directory.
- --compile
- Compile py files to pyc.
- --no-compile
- Do not compile py files to pyc.
- --no-use-wheel
- Do not find and prefer wheel archives when searching indexes and find-links locations.
- --pre
- Include pre-release and development versions. By default, pip only finds stable versions.
- --no-clean
-
Don't clean up build directories.
Package Index Options:
- -i,--index-url <url>
- Base URL of Python Package Index (default https://pypi.python.org/simple/).
- --extra-index-url <url>
- Extra URLs of package indexes to use in addition to --index-url.
- --no-index
- Ignore package index (only looking at --find-links URLs instead).
- -f,--find-links <url>
- If a url or path to an html file, then parse for links to archives. If a local path or file:// url that's a directory, then look for archives in the directory listing.
- --allow-external <package>
- Allow the installation of externally hosted files
- --allow-all-external
- Allow the installation of all externally hosted files
- --allow-unverified <package>
- Allow the installation of insecure and unverifiable files
- --process-dependency-links
- Enable the processing of dependency links.
UNINSTALL OPTIONS
pip is able to uninstall most installed packages. Known exceptions are:
- •
- Pure distutils packages installed with python setup.py install, which leave behind no metadata to determine what files were installed.
- •
- Script wrappers installed by python setup.py develop.
- -r,--requirement <file>
- Uninstall all the packages listed in the given requirements file. This option can be used multiple times.
- -y, --yes
- Don't ask for confirmation of uninstall deletions.
AUTHORS
This manual page was originally written by Jeff Licquia <licquia [at] debian.org>, later rewritten by Carl Chenet <chaica [at] debian.org>. It was rewritten again and the source converted to reStructuredText by Barry Warsaw <barry [at] debian.org>.
Permission is granted to copy, distribute and/or modify this document under the terms of the GNU General Public License, version 3 or any later version published by the Free Software Foundation.
AUTHOR
Barry Warsaw <barry [at] debian.org>