committed by
GitHub
1 changed files with 298 additions and 0 deletions
@ -0,0 +1,298 @@ |
|||||
|
# 环境变量 |
||||
|
|
||||
|
/// tip |
||||
|
|
||||
|
如果你已经知道什么是“环境变量”并且知道如何使用它们,你可以放心跳过这一部分。 |
||||
|
|
||||
|
/// |
||||
|
|
||||
|
环境变量(也称为“**env var**”)是一个独立于 Python 代码**之外**的变量,它存在于**操作系统**中,可以被你的 Python 代码(或其他程序)读取。 |
||||
|
|
||||
|
环境变量对于处理应用程序**设置**、作为 Python **安装**的一部分等方面非常有用。 |
||||
|
|
||||
|
## 创建和使用环境变量 |
||||
|
|
||||
|
你在 **shell(终端)**中就可以**创建**和使用环境变量,并不需要用到 Python: |
||||
|
|
||||
|
//// tab | Linux, macOS, Windows Bash |
||||
|
|
||||
|
<div class="termy"> |
||||
|
|
||||
|
```console |
||||
|
// 你可以使用以下命令创建一个名为 MY_NAME 的环境变量 |
||||
|
$ export MY_NAME="Wade Wilson" |
||||
|
|
||||
|
// 然后,你可以在其他程序中使用它,例如 |
||||
|
$ echo "Hello $MY_NAME" |
||||
|
|
||||
|
Hello Wade Wilson |
||||
|
``` |
||||
|
|
||||
|
</div> |
||||
|
|
||||
|
//// |
||||
|
|
||||
|
//// tab | Windows PowerShell |
||||
|
|
||||
|
<div class="termy"> |
||||
|
|
||||
|
```console |
||||
|
// 创建一个名为 MY_NAME 的环境变量 |
||||
|
$ $Env:MY_NAME = "Wade Wilson" |
||||
|
|
||||
|
// 在其他程序中使用它,例如 |
||||
|
$ echo "Hello $Env:MY_NAME" |
||||
|
|
||||
|
Hello Wade Wilson |
||||
|
``` |
||||
|
|
||||
|
</div> |
||||
|
|
||||
|
//// |
||||
|
|
||||
|
## 在 Python 中读取环境变量 |
||||
|
|
||||
|
你也可以在 Python **之外**的终端中创建环境变量(或使用任何其他方法),然后在 Python 中**读取**它们。 |
||||
|
|
||||
|
例如,你可以创建一个名为 `main.py` 的文件,其中包含以下内容: |
||||
|
|
||||
|
```Python hl_lines="3" |
||||
|
import os |
||||
|
|
||||
|
name = os.getenv("MY_NAME", "World") |
||||
|
print(f"Hello {name} from Python") |
||||
|
``` |
||||
|
|
||||
|
/// tip |
||||
|
|
||||
|
第二个参数是 <a href="https://docs.python.org/zh-cn/3.8/library/os.html#os.getenv" class="external-link" target="_blank">`os.getenv()`</a> 的默认返回值。 |
||||
|
|
||||
|
如果没有提供,默认值为 `None`,这里我们提供 `"World"` 作为默认值。 |
||||
|
|
||||
|
/// |
||||
|
|
||||
|
然后你可以调用这个 Python 程序: |
||||
|
|
||||
|
//// tab | Linux, macOS, Windows Bash |
||||
|
|
||||
|
<div class="termy"> |
||||
|
|
||||
|
```console |
||||
|
// 这里我们还没有设置环境变量 |
||||
|
$ python main.py |
||||
|
|
||||
|
// 因为我们没有设置环境变量,所以我们得到的是默认值 |
||||
|
|
||||
|
Hello World from Python |
||||
|
|
||||
|
// 但是如果我们事先创建过一个环境变量 |
||||
|
$ export MY_NAME="Wade Wilson" |
||||
|
|
||||
|
// 然后再次调用程序 |
||||
|
$ python main.py |
||||
|
|
||||
|
// 现在就可以读取到环境变量了 |
||||
|
|
||||
|
Hello Wade Wilson from Python |
||||
|
``` |
||||
|
|
||||
|
</div> |
||||
|
|
||||
|
//// |
||||
|
|
||||
|
//// tab | Windows PowerShell |
||||
|
|
||||
|
<div class="termy"> |
||||
|
|
||||
|
```console |
||||
|
// 这里我们还没有设置环境变量 |
||||
|
$ python main.py |
||||
|
|
||||
|
// 因为我们没有设置环境变量,所以我们得到的是默认值 |
||||
|
|
||||
|
Hello World from Python |
||||
|
|
||||
|
// 但是如果我们事先创建过一个环境变量 |
||||
|
$ $Env:MY_NAME = "Wade Wilson" |
||||
|
|
||||
|
// 然后再次调用程序 |
||||
|
$ python main.py |
||||
|
|
||||
|
// 现在就可以读取到环境变量了 |
||||
|
|
||||
|
Hello Wade Wilson from Python |
||||
|
``` |
||||
|
|
||||
|
</div> |
||||
|
|
||||
|
//// |
||||
|
|
||||
|
由于环境变量可以在代码之外设置、但可以被代码读取,并且不必与其他文件一起存储(提交到 `git`),因此通常用于配置或**设置**。 |
||||
|
|
||||
|
你还可以为**特定的程序调用**创建特定的环境变量,该环境变量仅对该程序可用,且仅在其运行期间有效。 |
||||
|
|
||||
|
要实现这一点,只需在同一行内、程序本身之前创建它: |
||||
|
|
||||
|
<div class="termy"> |
||||
|
|
||||
|
```console |
||||
|
// 在这个程序调用的同一行中创建一个名为 MY_NAME 的环境变量 |
||||
|
$ MY_NAME="Wade Wilson" python main.py |
||||
|
|
||||
|
// 现在就可以读取到环境变量了 |
||||
|
|
||||
|
Hello Wade Wilson from Python |
||||
|
|
||||
|
// 在此之后这个环境变量将不会依然存在 |
||||
|
$ python main.py |
||||
|
|
||||
|
Hello World from Python |
||||
|
``` |
||||
|
|
||||
|
</div> |
||||
|
|
||||
|
/// tip |
||||
|
|
||||
|
你可以在 <a href="https://12factor.net/zh_cn/config" class="external-link" target="_blank">The Twelve-Factor App: 配置</a>中了解更多信息。 |
||||
|
|
||||
|
/// |
||||
|
|
||||
|
## 类型和验证 |
||||
|
|
||||
|
这些环境变量只能处理**文本字符串**,因为它们是处于 Python 范畴之外的,必须与其他程序和操作系统的其余部分兼容(甚至与不同的操作系统兼容,如 Linux、Windows、macOS)。 |
||||
|
|
||||
|
这意味着从环境变量中读取的**任何值**在 Python 中都将是一个 `str`,任何类型转换或验证都必须在代码中完成。 |
||||
|
|
||||
|
你将在[高级用户指南 - 设置和环境变量](./advanced/settings.md)中了解更多关于使用环境变量处理**应用程序设置**的信息。 |
||||
|
|
||||
|
## `PATH` 环境变量 |
||||
|
|
||||
|
有一个**特殊的**环境变量称为 **`PATH`**,操作系统(Linux、macOS、Windows)用它来查找要运行的程序。 |
||||
|
|
||||
|
`PATH` 变量的值是一个长字符串,由 Linux 和 macOS 上的冒号 `:` 分隔的目录组成,而在 Windows 上则是由分号 `;` 分隔的。 |
||||
|
|
||||
|
例如,`PATH` 环境变量可能如下所示: |
||||
|
|
||||
|
//// tab | Linux, macOS |
||||
|
|
||||
|
```plaintext |
||||
|
/usr/local/bin:/usr/bin:/bin:/usr/sbin:/sbin |
||||
|
``` |
||||
|
|
||||
|
这意味着系统应该在以下目录中查找程序: |
||||
|
|
||||
|
- `/usr/local/bin` |
||||
|
- `/usr/bin` |
||||
|
- `/bin` |
||||
|
- `/usr/sbin` |
||||
|
- `/sbin` |
||||
|
|
||||
|
//// |
||||
|
|
||||
|
//// tab | Windows |
||||
|
|
||||
|
```plaintext |
||||
|
C:\Program Files\Python312\Scripts;C:\Program Files\Python312;C:\Windows\System32 |
||||
|
``` |
||||
|
|
||||
|
这意味着系统应该在以下目录中查找程序: |
||||
|
|
||||
|
- `C:\Program Files\Python312\Scripts` |
||||
|
- `C:\Program Files\Python312` |
||||
|
- `C:\Windows\System32` |
||||
|
|
||||
|
//// |
||||
|
|
||||
|
当你在终端中输入一个**命令**时,操作系统会在 `PATH` 环境变量中列出的**每个目录**中**查找**程序。 |
||||
|
|
||||
|
例如,当你在终端中输入 `python` 时,操作系统会在该列表中的**第一个目录**中查找名为 `python` 的程序。 |
||||
|
|
||||
|
如果找到了,那么操作系统将**使用它**;否则,操作系统会继续在**其他目录**中查找。 |
||||
|
|
||||
|
### 安装 Python 和更新 `PATH` |
||||
|
|
||||
|
安装 Python 时,可能会询问你是否要更新 `PATH` 环境变量。 |
||||
|
|
||||
|
//// tab | Linux, macOS |
||||
|
|
||||
|
假设你安装 Python 并最终将其安装在了目录 `/opt/custompython/bin` 中。 |
||||
|
|
||||
|
如果你同意更新 `PATH` 环境变量,那么安装程序将会将 `/opt/custompython/bin` 添加到 `PATH` 环境变量中。 |
||||
|
|
||||
|
它看起来大概会像这样: |
||||
|
|
||||
|
```plaintext |
||||
|
/usr/local/bin:/usr/bin:/bin:/usr/sbin:/sbin:/opt/custompython/bin |
||||
|
``` |
||||
|
|
||||
|
如此一来,当你在终端中输入 `python` 时,系统会在 `/opt/custompython/bin` 中找到 Python 程序(最后一个目录)并使用它。 |
||||
|
|
||||
|
//// |
||||
|
|
||||
|
//// tab | Windows |
||||
|
|
||||
|
假设你安装 Python 并最终将其安装在了目录 `C:\opt\custompython\bin` 中。 |
||||
|
|
||||
|
如果你同意更新 `PATH` 环境变量 (在 Python 安装程序中,这个操作是名为 `Add Python x.xx to PATH` 的复选框 —— 译者注),那么安装程序将会将 `C:\opt\custompython\bin` 添加到 `PATH` 环境变量中。 |
||||
|
|
||||
|
```plaintext |
||||
|
C:\Program Files\Python312\Scripts;C:\Program Files\Python312;C:\Windows\System32;C:\opt\custompython\bin |
||||
|
``` |
||||
|
|
||||
|
如此一来,当你在终端中输入 `python` 时,系统会在 `C:\opt\custompython\bin` 中找到 Python 程序(最后一个目录)并使用它。 |
||||
|
|
||||
|
//// |
||||
|
|
||||
|
因此,如果你输入: |
||||
|
|
||||
|
<div class="termy"> |
||||
|
|
||||
|
```console |
||||
|
$ python |
||||
|
``` |
||||
|
|
||||
|
</div> |
||||
|
|
||||
|
//// tab | Linux, macOS |
||||
|
|
||||
|
系统会在 `/opt/custompython/bin` 中**找到** `python` 程序并运行它。 |
||||
|
|
||||
|
这和输入以下命令大致等价: |
||||
|
|
||||
|
<div class="termy"> |
||||
|
|
||||
|
```console |
||||
|
$ /opt/custompython/bin/python |
||||
|
``` |
||||
|
|
||||
|
</div> |
||||
|
|
||||
|
//// |
||||
|
|
||||
|
//// tab | Windows |
||||
|
|
||||
|
系统会在 `C:\opt\custompython\bin\python` 中**找到** `python` 程序并运行它。 |
||||
|
|
||||
|
这和输入以下命令大致等价: |
||||
|
|
||||
|
<div class="termy"> |
||||
|
|
||||
|
```console |
||||
|
$ C:\opt\custompython\bin\python |
||||
|
``` |
||||
|
|
||||
|
</div> |
||||
|
|
||||
|
//// |
||||
|
|
||||
|
当学习[虚拟环境](virtual-environments.md)时,这些信息将会很有用。 |
||||
|
|
||||
|
## 结论 |
||||
|
|
||||
|
通过这个教程,你应该对**环境变量**是什么以及如何在 Python 中使用它们有了基本的了解。 |
||||
|
|
||||
|
你也可以在<a href="https://zh.wikipedia.org/wiki/%E7%8E%AF%E5%A2%83%E5%8F%98%E9%87%8F" class="external-link" target="_blank">环境变量 - 维基百科</a> (<a href="https://en.wikipedia.org/wiki/Environment_variable" class="external-link" target="_blank">Wikipedia for Environment Variable</a>) 中了解更多关于它们的信息。 |
||||
|
|
||||
|
在许多情况下,环境变量的用途和适用性并不是很明显。但是在开发过程中,它们会在许多不同的场景中出现,因此了解它们是很有必要的。 |
||||
|
|
||||
|
例如,你将在下一节关于[虚拟环境](virtual-environments.md)中需要这些信息。 |
Loading…
Reference in new issue