4. 在 Windows 上使用 Python
***************************

本文档旨在概述在 Microsoft Windows 上使用 Python 时应了解的特定于
Windows 的行为。

与大多数UNIX系统和服务不同，Windows系统没有预安装Python。多年来CPython
团队已经编译了每一个 发行版 的Windows安装程序（MSI 包），已便Windows
用户下载和安装。这些安装程序主要用于每个用户单独安装Python时，添加核心
解释器和库。安装程序还可以为一台机器的所有用户安装，并且可以为应用程序
本地分发提供单独的zip文件。

如 **PEP 11** 所述，Python 发布版对某个 Windows 平台的支持仅限于被
Microsoft 视为处于延长支持周期内的版本。 这意味着 Python 3.10 支持
Windows 8.1 及其后的版本。 如果你需要 Windows 7 支持，请安装 Python
3.8。

Windows提供了许多不同的安装程序，每个安装程序都有一定的优点和缺点。

完整安装程序 内含所有组件，对于使用Python 进行任何类型项目的开发人员而
言，它是最佳选择。

Microsoft Store包 是一个适用于运行脚本和包，并使用 IDLE 或其他开发环境
的简易 Python 安装版。 它需要 Windows 10 或更新的系统，但可以安全地安
装而不会破坏其他程序。 它还提供了许多便捷命令用来启动 Python 及其工具
。

nuget.org 安装包 是用于持续集成系统的轻量级安装。它可用于构建Python包
或运行脚本，但不可更新且没有用户界面工具。

可嵌入的包 是Python的最小安装包，适合嵌入到更大的应用程序中。


4.1. 完整安装程序
=================


4.1.1. 安裝步驟
---------------

四个 Python 3.10 安装程序可供下载 - 32位和64位版本的各有两个。 *web
installer* （网络安装包）是一个小的初始化工具，它将在安装过程中，根据
需要自动下载所需的组件。 *offline installer* （离线安装包）内含默认安
装所需的组件，可选择功能仍需要Internet连接下载。请参阅 當安裝時不下載
以了解在安装过程中避免下载的其他方法。

启动安装程序后，可以选择以下两个选项之一：

[圖片]

如果你選擇「馬上安裝」：

* 您 *不* 需要成为管理员（除非需要对C运行库进行系统更新，或者为所有用
  户安装 适用于Windows的Python启动器 ）

* Python将安装到您的用户目录中

* 适用于Windows的Python启动器 将根据第一页底部的选项安装

* 将安装标准库，测试套件，启动器和pip

* 如果選擇，安裝目錄將被加入到你的 "PATH"

* 安裝捷徑將只能被目前使用者所看見

選擇「客製化安裝」將允許你選擇所需的項目進行安裝，安裝位置與其他選擇或
安裝後的所需進行的動作。你將需要使用此選項「除錯特徵」或「二進位方式」
進行安裝。

如要为全部用户安装，应选择“自定义安装”。在这种情况下:

* 您可能需要提供管理凭据或批准

* Python 将安装到Program Files目录中

* 适用于Windows的Python启动器 将安装到Windows目录中

* 安装期间可以选择可选功能

* 标准库可以预编译为字节码

* 如果选中，安装目录将添加到系统 "PATH"

* 捷徑將被所有使用者所見


4.1.2. 删除 MAX_PATH 限制
-------------------------

历史上Windows的路径长度限制为260个字符。这意味着长于此的路径将无法解决
并导致错误。

在最新版本的 Windows 中，此限制可被扩展到大约 32,000 个字符。 但需要让
管理员激活“启用 Win32 长路径”组策略，或在注册表键
"HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Control\FileSystem" 中设
置 "LongPathsEnabled" 为 "1"。

这允许 "open()" 函数，"os" 模块和大多数其他路径功能接受并返回长度超过
260 个字符的路径。

更改上述选项后，无需进一步配置。

3.6 版更變: Python中启用了对长路径的支持。


4.1.3. 安裝排除使用者介面
-------------------------

安装程序UI中的所有选项也可以从命令行指定，允许脚本安装程序在许多机器上
复制安装，而无需用户交互。还可以在不禁用UI的情况下设置这些选项，以更改
一些默认值。

要完全隐藏安装程序UI并静默安装Python，请使用 "/quiet" 选项。要跳过用户
交互但仍然显示进度和错误，请使用 "/passive" 选项。可以通过
"/uninstall" 选项立即开始删除Python  - -   不会显示任何确认提示。

所有其他选项都传递为 "name=value" ，其中值通常是 "0" 来禁用某个特性，
"1" 来启用某个特性或路径。可用选项的完整列表如下所示。

+-----------------------------+----------------------------------------+----------------------------+
| 名称                        | 描述                                   | 預設                       |
|=============================|========================================|============================|
| InstallAllUsers             | 为所有用户安装。                       | 0                          |
+-----------------------------+----------------------------------------+----------------------------+
| TargetDir                   | 安裝目錄                               | 基于InstallAllUsers选择    |
+-----------------------------+----------------------------------------+----------------------------+
| DefaultAllUsersTargetDir    | 为所有用户安装时的默认安装路径         | "%ProgramFiles%\Python     |
|                             |                                        | X.Y" 或 "%ProgramFiles(x8  |
|                             |                                        | 6)%\Python X.Y"            |
+-----------------------------+----------------------------------------+----------------------------+
| DefaultJustForMeTargetDir   | 預設安裝目錄給 只有給我  安裝方式      | "%LocalAppData%\Programs\  |
|                             |                                        | Python\PythonXY" 或 "%Loc  |
|                             |                                        | alAppData%\Programs\Pytho  |
|                             |                                        | n\PythonXY-32" 或 "%Local  |
|                             |                                        | AppData%\Programs\Python\  |
|                             |                                        | PythonXY-64"               |
+-----------------------------+----------------------------------------+----------------------------+
| DefaultCustomTargetDir      | UI中显示的默认自定义安装目录           | （空）                     |
+-----------------------------+----------------------------------------+----------------------------+
| AssociateFiles              | 當執行程序也被安裝時創造檔案關聯       | 1                          |
+-----------------------------+----------------------------------------+----------------------------+
| CompileAll                  | 編譯所有 ".py" 檔案為 ".pyc"。         | 0                          |
+-----------------------------+----------------------------------------+----------------------------+
| PrependPath                 | 将install和Scripts目录添加到 "PATH" 以 | 0                          |
|                             | 及将 ".PY" 添加到 "PATHEXT"            |                            |
+-----------------------------+----------------------------------------+----------------------------+
| Shortcuts                   | 如果已安装，为解释器，文档和IDLE创建快 | 1                          |
|                             | 捷方式                                 |                            |
+-----------------------------+----------------------------------------+----------------------------+
| Include_doc                 | 安裝Python文件                         | 1                          |
+-----------------------------+----------------------------------------+----------------------------+
| Include_debug               | 安装调试二进制文件                     | 0                          |
+-----------------------------+----------------------------------------+----------------------------+
| Include_dev                 | 安装开发者头文件和库文件。 省略这一步  | 1                          |
|                             | 可能导致安装不可用。                   |                            |
+-----------------------------+----------------------------------------+----------------------------+
| Include_exe                 | 安装 "python.exe" 以及相关文件。忽略此 | 1                          |
|                             | 项可能会导致安装不可用。               |                            |
+-----------------------------+----------------------------------------+----------------------------+
| Include_launcher            | 安装 适用于Windows的Python启动器 .     | 1                          |
+-----------------------------+----------------------------------------+----------------------------+
| InstallLauncherAllUsers     | 为所有用户安装启动器。还需要           | 1                          |
|                             | "Include_launcher" 被设定为1           |                            |
+-----------------------------+----------------------------------------+----------------------------+
| Include_lib                 | 安装标准库和扩展模块。 省略这一步可能  | 1                          |
|                             | 导致安装不可用。                       |                            |
+-----------------------------+----------------------------------------+----------------------------+
| Include_pip                 | 安装捆绑的pip和setuptools              | 1                          |
+-----------------------------+----------------------------------------+----------------------------+
| Include_symbols             | 安装调试符号集 ("*.pdb")               | 0                          |
+-----------------------------+----------------------------------------+----------------------------+
| Include_tcltk               | 安装Tcl/Tk 支持和IDLE                  | 1                          |
+-----------------------------+----------------------------------------+----------------------------+
| Include_test                | 安装标准库测试套件                     | 1                          |
+-----------------------------+----------------------------------------+----------------------------+
| Include_tools               | 安装实用程序脚本                       | 1                          |
+-----------------------------+----------------------------------------+----------------------------+
| LauncherOnly                | 仅安装启动器。这将覆盖大多数其他选项。 | 0                          |
+-----------------------------+----------------------------------------+----------------------------+
| SimpleInstall               | 禁用大多数安装UI                       | 0                          |
+-----------------------------+----------------------------------------+----------------------------+
| SimpleInstallDescription    | 使用简化安装UI时显示的自定义消息。     | （空）                     |
+-----------------------------+----------------------------------------+----------------------------+

例如，要以静默方式全局安装默认的Python，您可以（在命令提示符>）使用以
下命令:

   python-3.9.0.exe /quiet InstallAllUsers=1 PrependPath=1 Include_test=0

要允许用户在没有测试套件的情况下轻松安装Python的个人副本，可以使用以下
命令提供快捷方式。这将显示一个简化的初始页面，不允许自定义:

   python-3.9.0.exe InstallAllUsers=0 Include_launcher=0 Include_test=0
       SimpleInstall=1 SimpleInstallDescription="Just for me, no test suite."

（请注意，省略启动器也会省略文件关联，并且仅在全局安装包含启动器时才建
议用于每用户安装。）

上面列出的选项也可以在一个名为 "unattend.xml" 的文件中与可执行文件一起
提供。此文件指定选项和值的列表。作为属性提供的值，（如果可能）它将转换
为数字。作为文本提供的值，始终保留为字符串。此示例文件设置与上一示例采
用相同的选项：

   <Options>
       <Option Name="InstallAllUsers" Value="no" />
       <Option Name="Include_launcher" Value="0" />
       <Option Name="Include_test" Value="no" />
       <Option Name="SimpleInstall" Value="yes" />
       <Option Name="SimpleInstallDescription">Just for me, no test suite</Option>
   </Options>


4.1.4. 當安裝時不下載
---------------------

由于下载的初始安装包中未包含Python的某些可选功能，如果选择安装这些功能
可能需要Internet连接。为了避免这种需要，可以按需下载所有可能的组件，以
创建一个完整的布局，该布局将不再需要internet连接，而不管所选择的特性是
什么。请注意，此下载可能比要求的要大，但是如果要执行大量安装，则拥有本
地缓存​​的副本非常有用。

从命令提示符执行以下命令以下载所有可能的必需文件。 请记得要将
"python-3.9.0.exe" 替换为安装程序的实际名称，并在单独的目录中创建子目
录以避免同名文件间的冲突。

   python-3.9.0.exe /layout [optional target directory]

您也可以指定 "/quiet" 选项来隐藏进度显示。


4.1.5. 修改安装
---------------

安装Python后，您可以通过Windows中的“程序和功能”工具添加或删除功能。选
择Python条目并选择“卸载/更改”以在维护模式下打开安装程序。

“修改” 允许您通过修改复选框来添加或删除功能 - 未更改的复选框将不会安装
或删除任何内容。在此模式下无法更改某些选项，例如安装目录；要修改这些，
您需要完全删除然后重新安装Python。

“修复” 将使用当前设置验证应安装的所有文件，并替换已删除或修改的任何文
件

“卸载” 将完全删除Python，但 适用于Windows的Python启动器 除外，它在“程
序和功能”中有自己的条目。


4.2. Microsoft Store包
======================

3.7.2 版新加入.

Microsoft Store 包是一个易于安装的 Python 解释器，主要针对在交互模式下
使用，例如用于教学。

要安装此软件包，请确保您拥有最新的Windows 10更新，并在Microsoft Store
应用程序中搜索 "Python 3.10" 。确保您选择的应用程序由 Python Software
Foundation 发布并安装。

警告:

  Python将始终在Microsoft Store上免费提供。如果要求您付款，则表示您没
  有选择正确的包。

安装完成后，可以在开始菜单中找到它来启动 Python。或者可以在命令提示符
或 PowerShell 会话中输入 "python" 来启动。此外可以输入 "pip" 或 "idle"
来使用 pip 和 IDLE。IDLE 也在开始菜单中。

所有这三个命令也可以使用版本号后缀，例如， "python3.exe" 和
"python3.x.exe" 以及 "python.exe" （其中 "3.x" 是您要启动的特定版本，
例如 3.10 ）。在 "设置-->主页-->应用和功能" 页面中，点选 "管理可选功能
" ，选择与每个命令关联的python版本。建议确保 "pip" 和 "idle" 与选择的
"python" 版本一致。

可以使用 "python -m venv" 创建虚拟环境并激活并正常使用。

如果你已经安装了另一个版本的Python并将它添加到你的 "PATH" 变量中，那么
它将作为 "python.exe" 而不是来自Microsoft Store的那个。要访问新安装，
请使用 "python3.exe" 或 "python3.x.exe" 。

"py.exe" 启动器将检测此 Python 安装版，但会优先使用来自传统安装器的安
装版。

要删除Python，请打开“设置”并使用“应用程序和功能”，或者在“开始”中找到
Python，然后右键单击以选择“卸载”。卸载将删除该已安装Python程序中的所有
软件包，但不会删除任何虚拟环境


4.2.1. 已知的问题
-----------------


4.2.1.1. 本地数据、注册表项和临时路径的重定向
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~

由于 Microsoft Store 应用程序的限制，Python 脚本可能无法对共享位置如
"TEMP" 和注册表进行完全写入访问。 相反同，它将写入到一个私有副本。 如
果你的脚本必须修改共享位置，则需要安装完整的安装器。

在运行时，Python 将使用知名 Windows 文件夹和注册表项的一个私有副本。
例如，如果环境变量 "%APPDATA%" 为 "c:\Users\<user>\AppData\"，则当写入
"C:\Users\<user>\AppData\Local" 时将会写入到 "C:\Users\<user>\AppData
\Local\Packages\PythonSoftwareFoundation.Python.3.8_qbz5n2kfra8p0\Loc
alCache\Local\"。

当读取文件时，Windows 将返回来自私有文件夹的文件，或者如果文件不存在，
则返回来自知名 Windows 目录的文件。 例如读取 "C:\Windows\System32" 将
返回 "C:\Windows\System32" 的内容加上 "C:\Program
Files\WindowsApps\package_name\VFS\SystemX86" 的内容。

你可以使用 "os.path.realpath()" 找到任何现有文件的真实路径:

   >>> import os
   >>> test_file = 'C:\\Users\\example\\AppData\\Local\\test.txt'
   >>> os.path.realpath(test_file)
   'C:\\Users\\example\\AppData\\Local\\Packages\\PythonSoftwareFoundation.Python.3.8_qbz5n2kfra8p0\\LocalCache\\Local\\test.txt'

当写入到 Windows 注册表时，会存在以下行为:

* 从 "HKLM\\Software" 读取是被允许的并且其结果将与包中的
  "registry.dat" 文件合并。

* 当相应的键/值存在时向 "HKLM\\Software" 写入，即修改现有键的值是不被
  允许的。

* 当包中相应的键/值不存在并且用户具有正确的访问权限时向
  "HKLM\\Software" 写入是被允许的。

有关此限制的技术原理的更多细节，请查询 Microsoft 已打包完全可信应用的
文档，当前位于 docs.microsoft.com/en-us/windows/msix/desktop/desktop-
to-uwp-behind-the-scenes


4.3. nuget.org 安装包
=====================

3.5.2 版新加入.

nuget.org 是一个精简的 Python 环境，用于在没有全局安装 Python 的系统的
持续集成和构建。 虽然 nuget 是“.NET的包管理器”，但是对于包含构建时工具
的包来说，它也可以很好地工作。

访问 nuget.org  获取有关使用 nuget 的最新信息。 下面的摘要对 Python 开
发人员来说已经足够了。

"nuget.exe" 命令行工具可以直接从 "https://aka.ms/nugetclidl" 下载，例
如，使用 curl 或 PowerShell。 使用该工具安装 64 位或 32 位最新版本的
Python:

   nuget.exe install python -ExcludeVersion -OutputDirectory .
   nuget.exe install pythonx86 -ExcludeVersion -OutputDirectory .

要选择特定版本，请添加 "-Version 3.x.y" 。 输出目录可以从 "." 更改，包
将安装到子目录中。 默认情况下，子目录的名称与包的名称相同，如果没有
"-ExcludeVersion" 选项，则此名称将包含已安装的特定版本。 子目录里面是
一个包含 Python 安装的 "tools" 目录：

   # Without -ExcludeVersion
   > .\python.3.5.2\tools\python.exe -V
   Python 3.5.2

   # With -ExcludeVersion
   > .\python\tools\python.exe -V
   Python 3.5.2

通常，nuget 包不可升级，应该平行安装较新版本并使用完整路径引用。 或者
，手动删除程序包目录并再次安装。 如果在构建之间不保留文件，许多 CI 系
统将自动执行此操作。

除了 "tools" 目录外，还有一个 "build\native" 目录。 它包含一个 MSBuild
属性文件 "python.props"，可以在 C++ 项目中使用该文件来引用 Python 安装
。 包含这些设置将自动在生成中使用标头和导入库。

nuget.org上的包信息页是 www.nuget.org/packages/python        对于64位
版本和 www.nuget.org/packages/pythonx86 表示32位版本。


4.4. 可嵌入的包
===============

3.5 版新加入.

嵌入式发行版是一个包含最小 Python 环境的 ZIP 文件。 它旨在作为另一个应
用程序的一部分，而不是由最终用户直接访问。

解压缩后，嵌入式发行版（几乎）与用户系统完全隔离，包括环境变量、系统注
册表设置和已安装的软件包。标准库作为预先编译和优化的 ".pyc" 文件包含在
ZIP中，并提供了 "python3.dll" ， "python37.dll" ， "python.exe" 和
"pythonw.exe" 文件。不包括Tcl/tk（包括所有依赖项，如Idle），pip和
Python文档。

備註:

  嵌入式发行版不包括 Microsoft C 运行时，应用程序安装程序负责提供此功
  能。 运行时可能已经预先安装在用户的系统上或通过 Windows Update 自动
  安装，并且可以通过在系统目录中找到 "ucrtbase.dll" 来检测。

第三方软件包应该由应用程序与嵌入式发行版一起安装。这个发行版不支持像常
规 Python 安装那样使用 pip 来管理依赖关系，不过可以小心地将 pip 包含进
来并使用它进行自动更新。 通常，第三方包应该作为应用程序的一部分(“打包
”)处理，以便开发人员在向用户提供更新之前能够确保与新版本兼容。

下面描述了这个发行版的两个推荐用例。


4.4.1. Python 应用程序
----------------------

用 Python 编写的应用程序并不一定要求用户了解这一事实。 在这种情况下，
可以使用嵌入式发行版在安装包中包含 Python 的私有版本。 根据它应该有多
透明（或者相反，它应该看起来有多专业），有两个选项。

使用专门的可执行文件作为启动程序需要一些编码，但为用户提供了最透明的体
验。使用定制的启动器，没有明显的迹象表明程序是在 Python 上运行的：图标
可以定制，公司和版本信息可以指定，文件关联可以正常运行。在大多数情况下
，自定义启动程序应该只需使用硬编码的命令行就能调用 "Py_Main"。

更简单的方法是提供批处理文件或生成的快捷方式，使用所需的命令行参数直接
调用 "python.exe" 或 "pythonw.exe"。在这种情况下，应用程序将显示为
Python 而不是其实际名称，并且用户可能无法将其与其他正在运行的 Python
进程或文件关联区分开来。

对于后一种方法，包应该与 Python 可执行文件一起作为目录安装，以确保它们
在路径上可用。 使用专用的启动器，包可以位于其他位置，因为在启动应用程
序之前有机会指定搜索路径。


4.4.2. 嵌入 Python
------------------

用本地代码编写的应用程序通常需要某种形式的脚本语言，嵌入式Python发行版
可以用于此目的。通常，应用程序的大部分都是本机代码，某些部分将调用
"python.exe" 或直接使用 "python3.dll" 。无论是哪种情况，将嵌入的发行版
解压缩到应用程序安装的子目录中就足以提供可加载的Python解释器。

与应用程序使用一样，包可以安装到任何位置，因为在初始化解释器之前有机会
指定搜索路径。否则，使用嵌入式发行版和常规安装之间没有根本区别。


4.5. 替代捆绑包
===============

除了标准的CPython发行版之外，还有一些包含附加功能的修改包。以下是热门
版本及其主要功能的列表：

ActivePython
   具有多平台兼容性的安装程序，文档，PyWin32

Anaconda
   流行的科学模块（如numpy，scipy和pandas）和 "conda" 包管理器。

Enthought Deployment Manager
   “下一代的 Python 环境和包管理器”

   之前 Enthought 提供了 Canopy，但已经 于 2016 年结束生命期。

WinPython
   特定于Windows的发行版，包含用于构建包的预构建科学包和工具。

请注意，这些软件包可能不包含最新版本的Python或其他库，并且不由核心
Python团队维护或支持。


4.6. 設定 Python
================

要从命令提示符方便地运行Python，您可以考虑在Windows中更改一些默认环境
变量。虽然安装程序提供了为您配置PATH和PATHEXT变量的选项，但这仅适用于
单版本、全局安装。如果您经常使用多个版本的Python，请考虑使用 适用于
Windows的Python启动器 。


4.6.1. 附录：设置环境变量
-------------------------

Windows允许在用户级别和系统级别永久配置环境变量，或临时在命令提示符中
配置环境变量。

要临时设置环境变量，请打开命令提示符并使用 **set** 命令：

   C:\>set PATH=C:\Program Files\Python 3.9;%PATH%
   C:\>set PYTHONPATH=%PYTHONPATH%;C:\My_python_lib
   C:\>python

这些环境变量的更改将应用​​于在该控制台中执行的任何其他命令，并且，由该
控制台启动的任何应用程序都继承设这些设置。

在百分号中包含的变量名将被现有值替换，允许在开始或结束时添加新值。通过
将包含 **python.exe** 的目录添加到开头来修改 "PATH"  是确保启动正确版
本的Python的常用方法。

要永久修改默认环境变量，请单击“开始”并搜索“编辑环境变量”，或打开系统属
性的 高级系统设置 ，然后单击 环境变量 按钮。在此对话框中，您可以添加或
修改用户和系统变量。要更改系统变量，您需要对计算机进行无限制访问（即管
理员权限）。

備註:

  Windows会将用户变量串联在系统变量 *之后* ，这可能会在修改 "PATH" 时
  导致意外结果。"PYTHONPATH" 变量被 Python 的所有版本使用，因此除非它
  列出的路径只包含与所有已安装的 Python 版本兼容的代码，否则不要永久配
  置此变量。

也參考:

  https://docs.microsoft.com/en-us/windows/win32/procthread
  /environment-variables
     Windows 上的環境變數概要

  https://docs.microsoft.com/en-us/windows-server/administration
  /windows-commands/set_1
     用于临时修改环境变量的 "set" 命令

  https://docs.microsoft.com/en-us/windows-server/administration
  /windows-commands/setx
     用于永久修改环境变量的 "setx" 命令


4.6.2. 查找Python可执行文件
---------------------------

3.5 版更變.

除了使用自动创建的Python解释器的开始菜单项之外，您可能还想在命令提示符
下启动Python。安装程序有一个选项可以为您设置。

在安装程序的第一页上，可以选择标记为“将Python添加到环境变量”的选项，以
使安装程序将安装位置添加到 "PATH" 。还添加了 "Scripts\" 文件夹的位置。
这允许你输入 **python** 来运行解释器，并且 **pip** 用于包安装程序。因
此，您还可以使用命令行选项执行脚本，请参阅 命令行 文档。

如果在安装时未启用此选项，则始终可以重新运行安装程序，选择“修改”并启用
它。或者，您可以使用 附录：设置环境变量 的方法手动修改 "PATH" 。您需要
将Python安装目录添加到 "PATH" 环境变量中，该内容与其他条目用分号分隔。
示例变量可能如下所示（假设前两个条目已经存在）:

   C:\WINDOWS\system32;C:\WINDOWS;C:\Program Files\Python 3.9


4.7. UTF-8 模式
===============

3.7 版新加入.

Windows 仍然使用传统编码格式作为系统的编码格式（ANSI 代码页）。 Python
使用它作为文本文件默认的编码格式 (即 "locale.getpreferredencoding()")
。

这可能会造成问题，因为因特网和大多数 Unix 系统包括 WSL (Windows
Subsystem for Linux) 广泛使用 UTF-8。

你可以使用 Python UTF-8 模式 将默认的文本编码格式改为 UTF-8。 要启用
Python UTF-8 模式 可以通过 "-X utf8" 命令行选项，或者 "PYTHONUTF8=1"
环境变量。 请参阅 "PYTHONUTF8" 了解如何启用 UTF-8 模式，并参阅 附录：
设置环境变量 了解如何修改环境变量。

当 Python UTF-8 模式 启用时，你仍然可以通过 "mbcs" 编解码器使用系统编
码格式（ANSI 代码页）。

请注意添加 "PYTHONUTF8=1" 到默认环境变量将会影响你的系统中的所有
Python 3.7+ 应用。 如果你有任何 Python 3.7+ 应用仍然依赖于传统的系统编
码格式，则推荐设置临时环境变量或使用 "-X utf8" 命令行选项。

備註:

  即使在不启用 UTF-8 模式时，Windows 版的 Python 也会在以下情况中默认
  使用 UTF-8：

  * 控制台 I/O 包括标准 I/O (详情见 **PEP 528**)。

  * *文件系统编码格式* (参见 **PEP 529** 了解详情)。


4.8. 适用于Windows的Python启动器
================================

3.3 版新加入.

用于Windows的Python启动器是一个实用程序，可帮助定位和执行不同的Python
版本。它允许脚本（或命令行）指示特定Python版本的首选项，并将定位并执行
该版本。

与 "PATH" 变量不同，启动器将正确选择最合适的Python版本。它更倾向于按用
户安装而不是系统安装，并按语言版本排序，而不是使用最新安装的版本。

启动器最初是在 **PEP 397** 中指定的。


4.8.1. 開始
-----------


4.8.1.1. 从命令行
~~~~~~~~~~~~~~~~~

3.6 版更變.

全局安装Python 3.3及更高版本将把启动器放在你的 "PATH" 上。启动程序与所
有可用的Python版本兼容，因此安装哪个版本无关紧要。要检查启动程序是否可
用，请在命令提示符中执行以下命令：

   py

您应该会发现已安装的最新版本的Python已启动 - 它可以正常退出，并且将指
定的任何其他命令行参数直接发送到Python。

如果您安装了多个版本的Python（例如，3.7和 3.10 ），您会注意到Python
3.10 启动 - 如果要启动 Python 3.7，尝试命令：

   py -3.7

如果您想使用已安装的 Python 2 的最新版本，请尝试以下命令：

   py -2

你会发现 Python 3.x 的最新版本已启动。

如果您看到以下错误，则表明您没有安装启动器：

   'py' is not recognized as an internal or external command,
   operable program or batch file.

除非在安装时选择了该选项，单个用户安装的Python不会将启动程序添加到
"PATH" 。

Tix 命令：

   py --list

显示当前已安装的Python版本。


4.8.1.2. 虛擬環境（Virtual environment）
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~

3.5 版新加入.

如果启动程序运行时没有明确的Python版本，并且虚拟环境（使用标准库创建
"venv" 模块或外部 "virtualenv" 工具）处于活动状态，则启动程序将运行虚
拟环境的解释器而不是全局的。要运行全局解释器，请停用虚拟环境，或显式指
定全局Python版本。


4.8.1.3. 从脚本
~~~~~~~~~~~~~~~

让我们创建一个测试Python脚本 - 创建一个名为 "hello.py" 的文件，其中包
含以下内容

   #! python
   import sys
   sys.stdout.write("hello from Python %s\n" % (sys.version,))

从hello.py所在的目录中，执行以下命令：

   py hello.py

您应该注意到最新的Python 2.x安装的版本号已打印出来。现在尝试将第一行更
改为：

   #! python3

现在重新执行该命令将打印最新的 Python 3.x 信息。 如上面的命令行示例一
样，你可以更明确地指定版本限定符。 假设你已安装了 Python 3.7，请尝试将
第一行改为 "#! python3.7" 那么你应当看到打印出了 3.7 的版本信息。

请注意，与交互式使用不同，裸“python”将使用您已安装的Python 2.x的最新版
本。这是为了向后兼容及兼容Unix，其中命令 "python" 通常是指Python 2。


4.8.1.4. 從檔案關聯
~~~~~~~~~~~~~~~~~~~

安装时应该将启动器与Python文件（即 ".py", ".pyw", ".pyc" 文件）相关联
。这意味着当您从Windows资源管理器中双击其中一个文件时，将使用启动程序
，因此您可以使用上述相同的工具让脚本指定应使用的版本。

这样做的主要好处是，单个启动程序可以同时支持多个Python版本，具体取决于
第一行的内容。


4.8.2. Shebang 行
-----------------

如果脚本文件的第一行以 "#!" 开头，则称为 "shebang" 行。Linux和其他类
Unix操作系统都有对这些行的本机支持，它们通常在此类系统上用来指示应该如
何执行脚本。这个启动器允许在Windows上对Python脚本使用相同的工具，上面
的示例演示了它们的使用。

为了允许Python脚本中的shebang行在Unix和Windows之间移植，该启动器支持许
多“虚拟”命令来指定要使用的解释器。支持的虚拟命令是：

* "/usr/bin/env python"

* "/usr/bin/python"

* "/usr/local/bin/python"

* "python"

例如，如果脚本开始的第一行为

   #! /usr/bin/python

将找到并使用默认的Python。因为在Unix上编写的许多Python脚本已经有了这一
行，你应该发现这些脚本可以由启动器使用而无需修改。如果您在Windows上编
写一个新脚本，希望在Unix上有用，那么您应该使用以 "/usr" 开头的一个
shebang行。

任何上述虚拟命令都可以显式指定版本（可以仅为主要版本，也可以为主要版本
加次要版本）作为后缀。 此外，可以通过在次要版本之后添加 “-32” 来请求
32 位版本。 例如 "/usr/bin/python3.7-32" 将请求使用 32 位 python 3.7。

3.7 版新加入: 从 python 启动器 3.7 开始，可以通过 "-64" 后缀调用 64 位
版本。 此外还可以指定一个主版本号加架构而不带次版本号 (即
"/usr/bin/python3-64")。

shebang line的 "/usr/bin/env" 形式还有一个特殊属性。在寻找已安装的
Python解释器之前，此表单将搜索可执行文件 "PATH" 以获取Python可执行文件
。这对应于Unix中 "env" 程序的行为，该程序将在 "PATH" 执行搜索。


4.8.3. shebang 行的参数
-----------------------

shebang 行还可以指定要传递给Python解释器的其他选项。 举例来说，如果你
有这样的 shebang 行：

   #! /usr/bin/python -v

那么 Python 将以 "-v" 选项启动


4.8.4. 自定义
-------------


4.8.4.1. 通过INI文件自定义
~~~~~~~~~~~~~~~~~~~~~~~~~~

启动程序将搜索两个.ini文件 - 在当前用户的 "application data" 目录中搜
索 "py.ini" （即通过使用 "CSIDL_LOCAL_APPDATA" 调用Windows函数
"SHGetFolderPath" 返回的目录）以及与启动器位于同一目录中的 "py.ini" 。
相同的.ini文件既用于启动器的“控制台”版本（即 py.exe），也用于“windows”
版本（即pyw.exe）

“应用程序目录”中指定的自定义优先于可执行文件旁边.ini文件的自定义，因此
对启动程序旁边的.ini文件不具有写访问权限的用户可以覆盖该全局.ini文件中
的命令。


4.8.4.2. 自定义默认的Python版本
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~

在某些情况下，可以在命令中包含版本限定符，以指定命令将使用哪个Python版
本。版本限定符以主版本号开头，可以选择后跟 ('.') 和次版本说明符。此外
，可以通过添加 "-32" 或 “-64” 来指定是请求32位还是64位实现。

例如，一个shebang 行的 "#!python" 行没有版本限定符，而 "#!python3" 有
一个版本限定符，它只指定一个主版本。

如果在命令中找不到版本限定符，则可以设置环境变量 "PY_PYTHON" 以指定默
认版本限定符。 如果未设置，则默认为 "3"。 该变量可以指定能通过命令行传
递的任何值，比如 "3", "3.7", "3.7-32" 或 "3.7-64"。 （请注意 "-64" 选
项仅适用于 Python 3.7 或更高版本中包含的启动器。）

如果没有找到次版本限定符，则可以设置环境变量 "PY_PYTHON{major}" （其中
"{major}" 是上面确定的当前主要版本限定符）以指定完整版本。如果没有找到
这样的选项，启动器将枚举已安装的Python版本并使用为主要版本找到的最新次
要版本，尽管不能保证，但该版本可能是该系列中最新安装的版本。

在安装了相同（major.minor）Python版本的32位和64位的64位Windows上，64位
版本将始终是首选。对于启动程序的32位和64位实现都是如此 -- 这对于启动程
序32位和64位都是正确的 -- 如果可用，32位启动程序将倾向于执行指定版本的
64位Python安装。这样就可以预测启动器的行为，只知道PC上安装了哪些版本，
而不考虑它们的安装顺序（即，不知道32位或64位版本的Python和相应的启动器
是否是最后安装）。如上所述，可以在版本说明符上使用可选的“-32”或“-64”后
缀来更改此行为。

範例：

* 如果没有设置相关选项，命令 "python" 和 "python2" 将使用安装的最新
  Python 2.x版本，命令 "python3" 将使用最新安装的Python 3.x.

* 命令 "python3.7" 根本不会查阅任何选项，因为版本已完全指定。

* 如果 "PY_PYTHON=3" ，命令 "python" 和 "python3" 都将使用最新安装的
  Python 3版本。

* 如果 "PY_PYTHON=3.7-32" ，命令 "python" 将使用3.7的32位实现，而命令
  "python3" 将使用最新安装的Python（PY_PYTHON根本没有被视为指定了主要
  版本。）

* 如果 "PY_PYTHON=3" 且 "PY_PYTHON3=3.7" ，命令 "python" 和 "python3"
  都将特别使用3.7

除环境变量外，还可以在启动程序使用的.INI文件中配置相同的设置。 INI文件
中的部分称为 "[defaults]" ，键名称将与没有前导 "PY_" 前缀的环境变量相
同（并注意INI文件中的键名不区分大小写） 。）环境变量的内容将覆盖INI文
件中指定的内容。

例如:

* 设置 "PY_PYTHON=3.7" 等同于包含以下内容的INI文件：

   [defaults]
   python=3.7

* 设置 "PY_PYTHON=3" 和 "PY_PYTHON3=3.7" 相当于包含以下内容的INI文件：

   [defaults]
   python=3
   python3=3.7


4.8.5. 诊断
-----------

如果设置了环境变量 "PYLAUNCH_DEBUG" （任何值），启动器将诊断信息打印到
stderr（即：控制台）。虽然这些信息同时具有冗长 *和* 简洁性，但它应该允
许您查看Python的版本、选择特定版本的原因以及用于执行目标Python的确切命
令行。


4.9. 查找模块
=============

Python通常将其库（以及您的site-packages文件夹）存储在安装目录中。因此
，如果您已将Python安装到 "C:\Python\" ，则默认库将驻留在
"C:\Python\Lib\" 中，第三方模块存储在 "C:\Python\Lib\site-packages\"
。

若要完全覆盖 "sys.path" ，请创建与DLL("python37._pth")或可执行文件
(“python._pth`”)同名的 "._pth" 文件，并为要添加的每个路径指定一行
"sys.path" 。基于DLL名称的文件覆盖基于可执行文件的文件，如果需要，可以
为加载运行时的任何程序限制路径。

当文件存在时，将忽略所有注册表和环境变量，启用隔离模式，并且：除非文件
中的一行指定 "import site" ，否则不会导入 "site" 。以 "＃" 开头的空白
路径和行将被忽略。每个路径可以是绝对的或相对于文件的位置。不允许使用除
"site" 以外的导入语句，并且不能指定任意代码。

请注意，当指定 "import site" 时， ".pth" 文件（没有前导下划线）将由
"site" 模块正常处理。

当找不到 "._pth" 文件时， "sys.path" 是如何在Windows上填充的：

* 在开始时，添加一个空条目，该条目对应于当前目录。

* 如果环境变量 "PYTHONPATH" 存在，如 环境变量 中所述，则接下来添加其条
  目。请注意，在Windows上，此变量中的路径必须用分号分隔，以区别于驱动
  器标识符中使用的冒号（ "C:\"  等）。

* 额外的 "应用程序路径" 可以作为子键被同时添加到注册表
  "HKEY_CURRENT_USER" 和 "HKEY_LOCAL_MACHINE" 分支下的
  "\SOFTWARE\Python\PythonCore{version}\PythonPath" 中。 以分号分隔的
  路径字符串作为默认值的子键将导致每个路径都被添加到 "sys.path" 中。
  （请注意所有已知的安装程序都只使用 HKLM，因此 HKCU 通常为空。）

* 如果设置了环境变量 "PYTHONHOME"  ，则将其假定为 “Python 主目录” 。否
  则，主Python可执行文件的路径用于定位 “landmark 文件” （ "Lib\os.py"
  或 "pythonXY.zip" ）以推断 ”Python 主目录“ 。如果找到了Python主目录
  ，则基于该文件夹将相关的子目录添加到 "sys.path" （"Lib" , "plat-win"
  等）。否则，核心Python路径是从存储在注册表中的PythonPath构造的。

* 如果找不到Python Home，也没有指定 "PYTHONPATH" 环境变量，并且找不到
  注册表项，则使用具有相对条目的默认路径（例如 ".\Lib; .\plat-win" 等
  等）。

如果在主可执行文件旁边或在可执行文件上一级的目录中找到 "pyvenv.cfg" 文
件，则以下变体适用：

* 如果 "home" 是一个绝对路径，并且 "PYTHONHOME" 未设置，则在推断起始位
  置时使用此路径而不是主可执行文件的路径。

最終這所有的結果為：

* 运行 "python.exe" ，或主Python目录中的任何其他.exe（安装版本，或直接
  来自PCbuild目录）时，推导出核心路径，并忽略注册表中的核心路径。始终
  读取注册表中的其他“应用程序路径”。

* 当Python托管在另一个.exe（不同的目录，通过COM嵌入等）时，将不会推断
  出“Python Home”，因此使用了来自注册表的核心路径。始终读取注册表中的
  其他“应用程序路径”。

* 如果Python找不到它的主目录并且没有注册表值（冻结的.exe，一些非常奇怪
  的安装设置），那么你会得到一条带有一些默认但相对的路径的路径。

对于那些想要将Python捆绑到其应用程序或发行版中的人，以下建议将防止与其
他安装冲突：

* 在您的可执行文件中包含一个 "._pth" 文件，其中包含目录。这将忽略注册
  表和环境变量中列出的路径，并忽略 "site" ，除非列出 "import site" 。

* 如果你在自己的可执行文件中加载 "python3.dll" 或 "python37.dll" ，在
  "Py_Initialize()" 之前，要显式调用 "Py_SetPath()"  或（至少）
  "Py_SetProgramName()"

* 清除 和/或 覆盖 "PYTHONPATH" 并在启动来自应用程序的 "python.exe" 之
  前设置 "PYTHONHOME" 。

* 如果您不能使用前面的建议（例如，您是一个允许人们直接运行
  "python.exe" 的分发版），请确保安装目录中存在 landmark 文件
  ("Lib\os.py")。 （请注意，在 ZIP 文件中不会检测到该文件，但会检测到
  正确命名的 ZIP 文件。）

这些将确保系统范围安装中的文件不会优先于与应用程序捆绑在一起的标准库的
副本。否则，用户可能会在使用您的应用程序时遇到问题请注意，第一个建议是
最好的，因为其他建议可能仍然容易受到注册表和用户站点包中的非标准路径的
影响。

   3.6 版更變:

   * 添加 "._pth" 文件支持并从 "pyvenv.cfg" 中删除 "applocal" 选项

   * 当直接与可执行文件相邻时，添加 "pythonXX.zip" 作为潜在的 landmark
     。

   3.6 版後已棄用:

   在 "Modules" （不是 "PythonPath" ）下的注册表中指定的模块可以通过以
   下方式导入 "importlib.machinery.WindowsRegistryFinder" 。在Windows
   上，此查找程序在3.6.0及更早版本的可用，但可能需要在将来显式添加到
   "sys.meta_path"


4.10. 附加模块
==============

尽管Python的目标是在所有平台中都可移植，但是Windows有一些独特的特性。
在标准库和外部都有一些模块和代码片段在使用这些特性。

特定于Windows的标准模块记录在 MS Windows 特有服務 中。


4.10.1. PyWin32
---------------

Mark Hammond 的 PyWin32  模块是一组用于高级Windows特定支持的模块。这包
括以下实用程序：

* 组件对象模型 (COM)

* Win32 API 调用

* 登錄檔（Registry）

* 事件日誌（Event log）

* Microsoft Foundation Classes (MFC) 用户界面

PythonWin 是PyWin32附带的一个示例MFC应用程序。它是一个内置调试器的可嵌
入IDE。

也參考:

  Win32 How Do I...?
     由 Tim Golden 所著

  Python and COM
     由 David 與 Paul Boddie 所著


4.10.2. cx_Freeze
-----------------

cx_Freeze 是一个 "distutils" 的扩展 (参见 扩展 Distutils)，它将 Python
脚本包装成可执行的 Windows 程序 ("***.exe" 文件)。 完成此操作后，你就
可以分发你的应用程序而无需用户安装 Python。


4.11. 編譯 Python 在 Windows
============================

如果你想要自己编译 CPython，首先要做的是获取 源代码。 你可以下载最新发
行版的源代码或是执行最新的 签出。

源代码树包含Microsoft Visual Studio的构建解决方案和项目文件，它是用于
构建官方Python版本的编译器。这些文件位于 "PCbuild" 目录中。

检查 "PCbuild/readme.txt" 以获取有关构建过程的一般信息。

有关扩展模块，请参阅 在 Windows 上构建 C 和 C++ 扩展 。


4.12. 其他平台
==============

随着Python的不断发展，不再支持以前曾经支持的一些平台（由于缺少用户或开
发人员）。检查 **PEP 11** 了解所有不支持的平台的详细信息。

* Windows CE 自 Python 3 起 不再受支持 (如果曾经受支持的话)。

* Cygwin <https://cygwin.com/>`_安装程序也提供了安装 `Python 解释器 的
  功能。

有关具有预编译安装程序平台的详细信息，请参阅 Python for Windows
