12. 虚拟环境和包

    这意味着一个Python安装可能无法满足每个应用程序的要求。如果应用程序A需要特定模块的1.0版本但应用程序B需要2.0版本,则需求存在冲突,安装版本1.0或2.0将导致某一个应用程序无法运行。

    这个问题的解决方案是创建一个 virtual environment,一个目录树,其中安装有特定Python版本,以及许多其他包。

    然后,不同的应用将可以使用不同的虚拟环境。 要解决先前需求相冲突的例子,应用程序 A 可以拥有自己的 安装了 1.0 版本的虚拟环境,而应用程序 B 则拥有安装了 2.0 版本的另一个虚拟环境。 如果应用程序 B 要求将某个库升级到 3.0 版本,也不会影响应用程序 A 的环境。

    用于创建和管理虚拟环境的模块称为 。venv 通常会安装你可用的最新版本的 Python。如果您的系统上有多个版本的 Python,您可以通过运行 或您想要的任何版本来选择特定的Python版本。

    要创建虚拟环境,请确定要放置它的目录,并将 模块作为脚本运行目录路径:

    如果它不存在,这将创建 tutorial-env 目录,并在其中创建包含Python解释器,标准库和各种支持文件的副本的目录。

    在Windows上,运行:

    1. tutorial-env\Scripts\activate.bat

    在Unix或MacOS上,运行:

    1. source tutorial-env/bin/activate

    (这个脚本是为bash shell编写的。如果你使用 cshfish shell,你应该改用 activate.cshactivate.fish 脚本。)

    激活虚拟环境将改变shell的命令提示来显示您正在使用的虚拟环境,以及改变当前环境,使运行``python``时能使用特定版本的Python安装。例如:

    1. $ source ~/envs/tutorial-env/bin/activate
    2. (tutorial-env) $ python
    3. Python 3.5.1 (default, May 6 2016, 10:59:36)
    4. ...
    5. >>> import sys
    6. >>> sys.path
    7. ['', '/usr/local/lib/python35.zip', ...,
    8. '~/envs/tutorial-env/lib/python3.5/site-packages']
    9. >>>

    你可以使用一个名为 pip 的程序来安装、升级和移除软件包。默认情况下 pip 将从 Python Package Index <https://pypi.org> 安装软件包。你可以在浏览器中访问 Python Package Index 或是使用 pip 受限的搜索功能:

    pip 有许多子命令: “install”, “uninstall”, “freeze” 等等。 (请在 指南页查看完整的 pip 文档。)

    1. (tutorial-env) $ pip install novas
    2. Collecting novas
    3. Downloading novas-3.1.1.3.tar.gz (136kB)
    4. Successfully installed novas-3.1.1.3

    您还可以通过提供包名称后跟 == 和版本号来安装特定版本的包:

    1. (tutorial-env) $ pip install requests==2.6.0
    2. Collecting requests==2.6.0
    3. Using cached requests-2.6.0-py2.py3-none-any.whl
    4. Installing collected packages: requests
    5. Successfully installed requests-2.6.0

    如果你重新运行这个命令,pip 会注意到已经安装了所请求的版本并且什么都不做。您可以提供不同的版本号来获取该版本,或者您可以运行 pip install --upgrade 将软件包升级到最新版本:

    1. (tutorial-env) $ pip install --upgrade requests
    2. Collecting requests
    3. Installing collected packages: requests
    4. Found existing installation: requests 2.6.0
    5. Uninstalling requests-2.6.0:
    6. Successfully uninstalled requests-2.6.0
    7. Successfully installed requests-2.7.0

    pip uninstall 后跟一个或多个包名称将从虚拟环境中删除包。

    pip show 将显示有关特定包的信息:

    pip list 将显示虚拟环境中安装的所有软件包:

    1. (tutorial-env) $ pip list
    2. novas (3.1.1.3)
    3. numpy (1.9.2)
    4. requests (2.7.0)
    5. setuptools (16.0)

    pip freeze` 将生成一个类似的已安装包列表,但输出使用 pip install 期望的格式。一个常见的约定是将此列表放在 requirements.txt 文件中:

    1. (tutorial-env) $ pip freeze > requirements.txt
    2. (tutorial-env) $ cat requirements.txt
    3. novas==3.1.1.3
    4. numpy==1.9.2
    5. requests==2.7.0
    1. (tutorial-env) $ pip install -r requirements.txt
    2. Collecting novas==3.1.1.3 (from -r requirements.txt (line 1))
    3. ...
    4. Collecting numpy==1.9.2 (from -r requirements.txt (line 2))
    5. ...
    6. Collecting requests==2.7.0 (from -r requirements.txt (line 3))
    7. ...
    8. Installing collected packages: novas, numpy, requests
    9. Running setup.py install for novas
    10. Successfully installed novas-3.1.1.3 numpy-1.9.2 requests-2.7.0

    pip 有更多选择。有关 的完整文档,请参阅 安装 Python 模块 指南。当您编写一个包并希望在 Python 包索引中使它可用时,请参考 指南。