查看全部 Python3 基础教程
介绍
Python 应用程序通常会使用标准库中没有的包和模块。应用程序有时需要特定版本的库以修复特定的 bug,或者应用程序可能是使用库接口的过时版本编写的。
这意味着安装一个 Python 可能无法满足每个应用程序的要求。如果应用程序 A 需要特定模块的 1.0 版本但应用程序 B 需要 2.0 版本,则需求就存在冲突了,无论安装 1.0 或 2.0 中的哪一个版本都将导致其中一个应用程序无法运行。
这个问题的解决方案是创建一个虚拟环境,这是一个自包含的目录树,其中安装了特定的 Python 版本,以及许多附加包。
然后,不同的应用可以使用不同的虚拟环境。要解决先前需求相冲突的例子,应用程序 A 可以拥有自己的安装了 1.0 版本的虚拟环境,而应用程序 B 可以拥有安装了 2.0 版本的另一个虚拟环境。如果应用程序 B 要求将某个库升级到 3.0 版本,也不会影响应用程序 A 的环境。
创建虚拟环境
用于创建和管理虚拟环境的模块称为 venv。venv
通常会安装用户可用的最新版本的 Python。如果用户的系统上有多个版本的 Python,则可以通过运行 python3
或想要的任何版本来选择特定的 Python 版本。
要创建虚拟环境,就要确定放置它的目录,并将 venv
模块作为脚本运行目录路径:
python3 -m venv tutorial-env
以上将会创建一个
tutorial-env
目录(如果它不存在),还会在其中创建包含 Python 解释器、标准库和各种支持文件的副本等多个目录。
虚拟环境的常用目录位置是 .venv
,这个名称通常会让该目录在终端中不可见,因此避免了给它起一个需要解释其存在的名称。它还能防止与某些工具所支持的 .env
环境变量定义文件发生冲突。
创建好虚拟环境后,就可以激活它。
-
在 Windows 上,运行:
tutorial-env\Scripts\activate.bat
-
在 Unix 或 MacOS 上,运行:
source tutorial-env/bin/activate
这个脚本是为 bash shell 编写的。如果用 csh 或 fish shell,就该改用
activate.csh
或activate.fish
脚本。
激活虚拟环境会改变 shell 的提示符以显示当前使用的虚拟环境,还会修改环境使得运行的 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']
>>>
用 pip 管理包
可以使用一个名为 pip
的程序来安装、升级和移除包。默认情况下,pip
将从 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
如果重新运行这个命令,pip
会注意到所要求的版本已经安装并会什么都不做。可以提供特定的版本号来获取该版本,或运行 pip install --upgrade
将包升级到最新版本:
(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
pip uninstall
后跟一个或多个包名可以从虚拟环境中删除指定的包。
pip show
可以显示特定包的信息:
(tutorial-env) $ 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:
pip list
可以显示虚拟环境中已安装的所有包:
(tutorial-env) $ pip list
novas (3.1.1.3)
numpy (1.9.2)
pip (7.0.3)
requests (2.7.0)
setuptools (16.0)
pip freeze
可以生成一个类似的已安装包列表,但其输出会使用 pip install
期望的格式。一个常见的约定是将此列表放在 requirements.txt
文件中:
(tutorial-env) $ 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
还有很多配置项,具体可以参考 Python 模块安装指南。如果想将自己编写的包放到 Python Package Index,可以参考 Python 包分发指南。