12. 虛擬環(huán)境和包?

12.1. 概述?

Python應用程序通常會使用不在標準庫內(nèi)的軟件包和模塊。應用程序有時需要特定版本的庫,因為應用程序可能需要修復特定的錯誤,或者可以使用庫的過時版本的接口編寫應用程序。

這意味著一個Python安裝可能無法滿足每個應用程序的要求。如果應用程序A需要特定模塊的1.0版本但應用程序B需要2.0版本,則需求存在沖突,安裝版本1.0或2.0將導致某一個應用程序無法運行。

這個問題的解決方案是創(chuàng)建一個 virtual environment,一個目錄樹,其中安裝有特定Python版本,以及許多其他包。

然后,不同的應用將可以使用不同的虛擬環(huán)境。 要解決先前需求相沖突的例子,應用程序 A 可以擁有自己的 安裝了 1.0 版本的虛擬環(huán)境,而應用程序 B 則擁有安裝了 2.0 版本的另一個虛擬環(huán)境。 如果應用程序 B 要求將某個庫升級到 3.0 版本,也不會影響應用程序 A 的環(huán)境。

12.2. 創(chuàng)建虛擬環(huán)境?

用于創(chuàng)建和管理虛擬環(huán)境的模塊稱為 venvvenv 通常會安裝你可用的最新版本的 Python。如果您的系統(tǒng)上有多個版本的 Python,您可以通過運行 python3 或您想要的任何版本來選擇特定的Python版本。

要創(chuàng)建虛擬環(huán)境,請確定要放置它的目錄,并將 venv 模塊作為腳本運行目錄路徑:

python3 -m venv tutorial-env

這將創(chuàng)建 tutorial-env 目錄,如果它不存在的話,并在其中創(chuàng)建包含 Python 解釋器副本和各種支持文件的目錄。

虛擬環(huán)境的常用目錄位置是 .venv。 這個名稱通常會令該目錄在你的終端中保持隱藏,從而避免需要對所在目錄進行額外解釋的一般名稱。 它還能防止與某些工具所支持的 .env 環(huán)境變量定義文件發(fā)生沖突。

創(chuàng)建虛擬環(huán)境后,您可以激活它。

在Windows上,運行:

tutorial-env\Scripts\activate

在Unix或MacOS上,運行:

source tutorial-env/bin/activate

(這個腳本是為bash shell編寫的。如果你使用 cshfish shell,你應該改用 activate.cshactivate.fish 腳本。)

激活虛擬環(huán)境將改變你所用終端的提示符,以顯示你正在使用的虛擬環(huán)境,并修改環(huán)境以使 python 命令所運行的將是已安裝的特定 Python 版本。 例如:

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

To deactivate a virtual environment, type:

deactivate

into the terminal.

12.3. 使用pip管理包?

你可以使用一個名為 pip 的程序來安裝、升級和移除軟件包。 默認情況下 pip 將從 Python Package Index <https://pypi.org> 安裝軟件包。 你可以在你的 web 瀏覽器中查看 Python Package Index。

pip 有許多子命令: "install", "uninstall", "freeze" 等等。 (請在 安裝 Python 模塊 指南頁查看完整的 pip 文檔。)

您可以通過指定包的名稱來安裝最新版本的包:

(tutorial-env) $ python -m pip install novas
Collecting novas
  Downloading novas-3.1.1.3.tar.gz (136kB)
Installing collected packages: novas
  Running setup.py install for novas
Successfully installed novas-3.1.1.3

您還可以通過提供包名稱后跟 == 和版本號來安裝特定版本的包:

(tutorial-env) $ python -m pip install requests==2.6.0
Collecting requests==2.6.0
  Using cached requests-2.6.0-py2.py3-none-any.whl
Installing collected packages: requests
Successfully installed requests-2.6.0

If you re-run this command, pip will notice that the requested version is already installed and do nothing. You can supply a different version number to get that version, or you can run python -m pip install --upgrade to upgrade the package to the latest version:

(tutorial-env) $ python -m pip install --upgrade requests
Collecting requests
Installing collected packages: requests
  Found existing installation: requests 2.6.0
    Uninstalling requests-2.6.0:
      Successfully uninstalled requests-2.6.0
Successfully installed requests-2.7.0

python -m pip uninstall followed by one or more package names will remove the packages from the virtual environment.

python -m pip show will display information about a particular package:

(tutorial-env) $ python -m pip show requests
---
Metadata-Version: 2.0
Name: requests
Version: 2.7.0
Summary: Python HTTP for Humans.
Home-page: http://python-requests.org
Author: Kenneth Reitz
Author-email: me@kennethreitz.com
License: Apache 2.0
Location: /Users/akuchling/envs/tutorial-env/lib/python3.4/site-packages
Requires:

python -m pip list will display all of the packages installed in the virtual environment:

(tutorial-env) $ python -m pip list
novas (3.1.1.3)
numpy (1.9.2)
pip (7.0.3)
requests (2.7.0)
setuptools (16.0)

python -m pip freeze will produce a similar list of the installed packages, but the output uses the format that python -m pip install expects. A common convention is to put this list in a requirements.txt file:

(tutorial-env) $ python -m pip freeze > requirements.txt
(tutorial-env) $ cat requirements.txt
novas==3.1.1.3
numpy==1.9.2
requests==2.7.0

然后可以將 requirements.txt 提交給版本控制并作為應用程序的一部分提供。然后用戶可以使用 install -r 安裝所有必需的包:

(tutorial-env) $ python -m pip install -r requirements.txt
Collecting novas==3.1.1.3 (from -r requirements.txt (line 1))
  ...
Collecting numpy==1.9.2 (from -r requirements.txt (line 2))
  ...
Collecting requests==2.7.0 (from -r requirements.txt (line 3))
  ...
Installing collected packages: novas, numpy, requests
  Running setup.py install for novas
Successfully installed novas-3.1.1.3 numpy-1.9.2 requests-2.7.0

pip 有更多選擇。有關 pip 的完整文檔,請參閱 安裝 Python 模塊 指南。當您編寫一個包并希望在 Python 包索引中使它可用時,請參考 分發(fā) Python 模塊 指南。