Requirement Specifiers¶
pip supports installing from a package index using a requirement specifier. Generally speaking, a requirement specifier is composed of a project name followed by optional version specifiers.
PEP 508 contains a full specification of the format of a requirement.
Added in version 6.0: Support for environment markers.
Added in version 19.1: Support for the direct URL reference form.
Overview¶
A requirement specifier comes in two forms:
name-based, which is composed of:
a package name (eg:
requests
)optionally, a set of “extras” that serve to install optional dependencies (eg:
security
)optionally, constraints to apply on the version of the package
optionally, environment markers
URL-based, which is composed of:
a package name (eg:
requests
)optionally, a set of “extras” that serve to install optional dependencies (eg:
security
)a URL for the package
optionally, environment markers
Examples¶
A few example name-based requirement specifiers:
SomeProject
SomeProject == 1.3
SomeProject >= 1.2, < 2.0
SomeProject[foo, bar]
SomeProject ~= 1.4.2
SomeProject == 5.4 ; python_version < '3.8'
SomeProject ; sys_platform == 'win32'
requests [security] >= 2.8.1, == 2.8.* ; python_version < "2.7"
Note
Use quotes around specifiers in the shell when using >
, <
, or when using environment markers.
Do not use quotes in requirement files. There is only one exception: pip v7.0 and v7.0.1 (from May 2015) required quotes around specifiers containing environment markers in requirement files.
A few example URL-based requirement specifiers:
pip @ https://github.com/pypa/pip/archive/22.0.2.zip
requests [security] @ https://github.com/psf/requests/archive/refs/heads/main.zip ; python_version >= "3.11"