An implementation of the py
command for UNIX-based platforms.
The goal is to have py
become the cross-platform command that all Python users
use when executing a Python interpreter. By having a version-agnostic command
it side-steps the "what should the python
command point to?" debate by
clearly specifying that upfront (i.e. the newest version of Python that is
installed). This also unifies the suggested command to document which needs to
target both Windows as UNIX as py
has existed as the preferred command on
Windows for some time.
Please note that at various points in searching for the most appropriate Python version that the version being searched for can become more specific. This leads to a switch in the search algorithm to one more appropriate to the specificity of the version.
py -3.6
(specific version)PATH
for python3.6
py -3
(loose/major version)PY_PYTHON3
environment variable if defined
(e.g. PY_PYTHON3=3.6
)PATH
for all instances of python3.Y
Y
py
(any/unknown version)/usr/bin/python
, /usr/local/bin/python
,
/usr/bin/env python
or python
, proceed based on the version found
(bare python
is considered python2
for backwards-compatibility)python
is considered python2
for backwards compatibility
(because of this the search will not continue as if no version details
were known)${VIRTUAL_ENV}/bin/python
immediately if availablePY_PYTHON
environment variable if defined
(e.g. PY_PYTHON=3
or PY_PYTHON=3.6
)PATH
for all instances of pythonX.Y
X.Y
NOTE: I am using this project to learn Rust, so please don't be offended if I choose to implement something myself instead of accepting a pull request that you submit. (Pull requests to do something I have already implemented in a more idiomatic fashion are very much appreciated, though.)
PEP 397: Python launcher for Windows (documentation)
PYLAUNCH_DEBUG
py -0
/py --list
/py -0p
/py --list-paths
pip list
?py -h
emits its own help before continuing on to call python
Pipfile
/Pipfile.lock
and its python_version
field?pyenv
and its .python-version
or PYENV_VERSION
?2.7-framework=/System/Library/Frameworks/Python.framework/Versions/2.7/Resources/Python.app/Contents/MacOS/Python
?2.7=/System/Library/Frameworks/Python.framework/Versions/2.7/Resources/Python.app/Contents/MacOS/Python