本文档旨在概述在 Microsoft Windows 上使用 Python 时应了解的特定于 Windows 的行为。
与大多数UNIX系统和服务不同,Windows系统没有预安装Python。多年来CPython 团队已经编译了每一个 的Windows安装程序(MSI 包),已便Windows 用户下载和安装。这些安装程序主要用于每个用户单独安装Python时,添加核心解释器和库。安装程序还可以为一台机器的所有用户安装,并且可以为应用程序本地分发提供单独的zip文件。
如 中所述,Python 仅支持微软产品支持生命周期内的Windows 版本。这意味着 Python 3.8 支持Windows Vista和更新版本。如果需要Windows XP支持,请安装Python 3.4。
Windows提供了许多不同的安装程序,每个安装程序都有一定的优点和缺点。
内含所有组件,对于使用Python 进行任何类型项目的开发人员而言,它是最佳选择。
是一个简单的Python 安装,适用于运行脚本和包,以及使用IDLE或其他开发环境。 它需要Windows 10,但可以安全地安装而不会破坏其他程序。 它还提供了许多方便的命令来启动Python及其工具。
是用于持续集成系统的轻量级安装。它可用于构建Python包或运行脚本,但不可更新且没有用户界面工具。
是Python的最小安装包,适合嵌入到更大的应用程序中。
四个 Python 3.8 安装程序可供下载 - 32位和64位版本的各有两个。 web installer (网络安装包)是一个小的初始化工具,它将在安装过程中,根据需要自动下载所需的组件。 offline installer (离线安装包)内含默认安装所需的组件,可选择功能仍需要Internet连接下载。请参阅 以了解在安装过程中避免下载的其他方法。
启动安装程序后,可以选择以下两个选项之一:
如果选择“Install Now(立即安装)”:
选择“自定义安装”将允许您选择:要安装的功能、安装位置、其他选项或安装后的操作。如果要安装调试符号或二进制文件,您需要使用此选项。
如要为全部用户安装,应选择“自定义安装”。在这种情况下:
历史上Windows的路径长度限制为260个字符。这意味着长于此的路径将无法解决并导致错误。
在最新版本的 Windows 中,此限制可被扩展到大约 32,000 个字符。 但需要让管理员激活“启用 Win32 长路径”组策略,或在注册表键 中设置 为 。
这允许 函数, 模块和大多数其他路径功能接受并返回长度超过 260 个字符的路径。
更改上述选项后,无需进一步配置。
安装程序UI中的所有选项也可以从命令行指定,允许脚本安装程序在许多机器上复制安装,而无需用户交互。还可以在不禁用UI的情况下设置这些选项,以更改一些默认值。
要完全隐藏安装程序UI并静默安装Python,请使用 选项。要跳过用户交互但仍然显示进度和错误,请使用 选项。可以通过 选项立即开始删除Python - - 不会显示任何提示。
所有其他选项都传递为 ,其中值通常是 来禁用某个特性, 来启用某个特性或路径。可用选项的完整列表如下所示。
例如,要以静默方式全局安装默认的Python,您可以(在命令提示符>)使用以下命令:
要允许用户在没有测试套件的情况下轻松安装Python的个人副本,可以使用以下命令提供快捷方式。这将显示一个简化的初始页面,不允许自定义:
(请注意,省略启动器也会省略文件关联,并且仅在全局安装包含启动器时才建议用于每用户安装。)
上面列出的选项也可以在一个名为 的文件中与可执行文件一起提供。此文件指定选项和值的列表。作为属性提供的值,(如果可能)它将转换为数字。作为文本提供的值,始终保留为字符串。此示例文件设置与上一示例采用相同的选项:
由于下载的初始安装包中未包含Python的某些可选功能,如果选择安装这些功能可能需要Internet连接。为了避免这种需要,可以按需下载所有可能的组件,以创建一个完整的布局,该布局将不再需要internet连接,而不管所选择的特性是什么。请注意,此下载可能比要求的要大,但是如果要执行大量安装,则拥有本地缓存的副本非常有用。
从命令提示符执行以下命令以下载所有可能的必需文件。请记住将 替换为安装程序的实际名称,并在自己的目录中创建布局,以避免同名的文件之间发生冲突。
您也可以指定 选项来隐藏进度显示。
安装Python后,您可以通过Windows中的“程序和功能”工具添加或删除功能。选择Python条目并选择“卸载/更改”以在维护模式下打开安装程序。
“修改” 允许您通过修改复选框来添加或删除功能 - 未更改的复选框将不会安装或删除任何内容。在此模式下无法更改某些选项,例如安装目录;要修改这些,您需要完全删除然后重新安装Python。
“修复” 将使用当前设置验证应安装的所有文件,并替换已删除或修改的任何文件
“卸载” 将完全删除Python,但 除外,它在“程序和功能”中有自己的条目。
Microsoft Store 包是一个易于安装的 Python 解释器,主要针对在交互模式下使用,例如用于教学。
要安装此软件包,请确保您拥有最新的Windows 10更新,并在Microsoft Store应用程序中搜索 "Python 3.8" 。确保您选择的应用程序由 Python Software Foundation 发布并安装。
安装完成后,可以在开始菜单中找到它来启动 Python。或者可以在命令提示符或 PowerShell 会话中输入 来启动。此外可以输入 或 来使用 pip 和 IDLE。IDLE 也在开始菜单中。
所有这三个命令也可以使用版本号后缀,例如, 和 以及 (其中 是您要启动的特定版本,例如 3.8 )。在 页面中,点选 ,选择与每个命令关联的python版本。建议确保 和 与选择的 版本一致。
可以使用 创建虚拟环境并激活并正常使用。
如果你已经安装了另一个版本的Python并将它添加到你的 变量中,那么它将作为 而不是来自Microsoft Store的那个。要访问新安装,请使用 或 。
启动器将检测此 Python 安装版,但会优先使用来自传统安装器的安装版。
要删除Python,请打开“设置”并使用“应用程序和功能”,或者在“开始”中找到Python,然后右键单击以选择“卸载”。卸载将删除该已安装Python程序中的所有软件包,但不会删除任何虚拟环境
由于Microsoft Store应用程序的限制,Python脚本可能无法对共享位置(如 )和注册表进行完全写入访问。相反,它将写入私人副本。如果脚本必须修改共享位置,则需要安装完整安装程序。
有关此限制的技术原理的更多细节,请查询 Microsoft 已打包完全可信应用的文档,当前位于
nuget.org 是一个精简的 Python 环境,用于在没有全局安装 Python 的系统的持续集成和构建。 虽然 nuget 是“.NET的包管理器”,但是对于包含构建时工具的包来说,它也可以很好地工作。
访问 获取有关使用 nuget 的最新信息。 下面的摘要对 Python 开发人员来说已经足够了。
命令行工具可以直接从 下载,例如,使用 curl 或 PowerShell。 使用该工具安装 64 位或 32 位最新版本的 Python:
要选择特定版本,请添加 。输出目录可以从 更改,包将安装到子目录中。默认情况下,子目录的名称与包的名称相同,如果没有 选项,则此名称将包含已安装的特定版本。子目录里面是一个包含Python安装的 目录:
通常,nuget 包不可升级,应该平行安装较新版本并使用完整路径引用。 或者,手动删除程序包目录并再次安装。 如果在构建之间不保留文件,许多 CI 系统将自动执行此操作。
除了 目录外,还有一个 目录。 它包含一个 MSBuild 属性文件 ,可以在 C++ 项目中使用该文件来引用 Python 安装。 包含这些设置将自动在生成中使用标头和导入库。
nuget.org上的包信息页是 对于64位版本和 表示32位版本。
嵌入式发行版是一个包含最小 Python 环境的 ZIP 文件。 它旨在作为另一个应用程序的一部分,而不是由最终用户直接访问。
解压缩后,嵌入式发行版(几乎)与用户系统完全隔离,包括环境变量、系统注册表设置和已安装的软件包。标准库作为预先编译和优化的 文件包含在ZIP中,并提供了 , , 和 文件。不包括Tcl/tk(包括所有依赖项,如Idle),pip和Python文档。
第三方软件包应该由应用程序与嵌入式发行版一起安装。这个发行版不支持像常规 Python 安装那样使用 pip 来管理依赖关系,不过可以小心地将 pip 包含进来并使用它进行自动更新。 通常,第三方包应该作为应用程序的一部分(“打包”)处理,以便开发人员在向用户提供更新之前能够确保与新版本兼容。
下面描述了这个发行版的两个推荐用例。
用 Python 编写的应用程序并不一定要求用户了解这一事实。 在这种情况下,可以使用嵌入式发行版在安装包中包含 Python 的私有版本。 根据它应该有多透明(或者相反,它应该看起来有多专业),有两个选项。
使用专门的可执行文件作为启动程序需要一些编码,但为用户提供了最透明的体验。使用定制的启动器,没有明显的迹象表明程序是在 Python 上运行的:图标可以定制,公司和版本信息可以指定,文件关联可以正常运行。在大多数情况下,自定义启动程序应该只需使用硬编码的命令行就能调用 。
更简单的方法是提供批处理文件或生成的快捷方式,使用所需的命令行参数直接调用 或 。在这种情况下,应用程序将显示为 Python 而不是其实际名称,并且用户可能无法将其与其他正在运行的 Python 进程或文件关联区分开来。
对于后一种方法,包应该与 Python 可执行文件一起作为目录安装,以确保它们在路径上可用。 使用专用的启动器,包可以位于其他位置,因为在启动应用程序之前有机会指定搜索路径。
用本地代码编写的应用程序通常需要某种形式的脚本语言,嵌入式Python发行版可以用于此目的。通常,应用程序的大部分都是本机代码,某些部分将调用 或直接使用 。无论是哪种情况,将嵌入的发行版解压缩到应用程序安装的子目录中就足以提供可加载的Python解释器。
与应用程序使用一样,包可以安装到任何位置,因为在初始化解释器之前有机会指定搜索路径。否则,使用嵌入式发行版和常规安装之间没有根本区别。
除了标准的CPython发行版之外,还有一些包含附加功能的修改包。以下是热门版本及其主要功能的列表:
请注意,这些软件包可能不包含最新版本的Python或其他库,并且不由核心Python团队维护或支持。
要从命令提示符方便地运行Python,您可以考虑在Windows中更改一些默认环境变量。虽然安装程序提供了为您配置PATH和PATHEXT变量的选项,但这仅适用于单版本、全局安装。如果您经常使用多个版本的Python,请考虑使用 。
Windows允许在用户级别和系统级别永久配置环境变量,或临时在命令提示符中配置环境变量。
要临时设置环境变量,请打开命令提示符并使用 命令:
这些环境变量的更改将应用于在该控制台中执行的任何其他命令,并且,由该控制台启动的任何应用程序都继承设这些设置。
在百分号中包含的变量名将被现有值替换,允许在开始或结束时添加新值。通过将包含 的目录添加到开头来修改 是确保启动正确版本的Python的常用方法。
要永久修改默认环境变量,请单击“开始”并搜索“编辑环境变量”,或打开系统属性的 ,然后单击 按钮。在此对话框中,您可以添加或修改用户和系统变量。要更改系统变量,您需要对计算机进行无限制访问(即管理员权限)。
除了使用自动创建的Python解释器的开始菜单项之外,您可能还想在命令提示符下启动Python。安装程序有一个选项可以为您设置。
在安装程序的第一页上,可以选择标记为“将Python添加到环境变量”的选项,以使安装程序将安装位置添加到 。还添加了 文件夹的位置。这允许你输入 来运行解释器,并且 用于包安装程序。因此,您还可以使用命令行选项执行脚本,请参阅 文档。
如果在安装时未启用此选项,则始终可以重新运行安装程序,选择“修改”并启用它。或者,您可以使用 的方法手动修改 。您需要将Python安装目录添加到 环境变量中,该内容与其他条目用分号分隔。示例变量可能如下所示(假设前两个条目已经存在):
Windows 仍然使用传统编码格式作为系统的编码格式(ANSI 代码页)。 Python 使用它作为文本文件默认的编码格式 (即 )。
这可能会造成问题,因为因特网和大多数 Unix 系统包括 WSL (Windows Subsystem for Linux) 广泛使用 UTF-8。
你可以使用 UTF-8 模式将默认的文本编码格式改为 UTF-8。 要启用 UTF-8 模式可以通过 命令行选项,或者 环境变量。 请参见 了解如何启用 UTF-8 模式,并参见 了解如何修改环境变量。
当 UTF-8 模式被启用时:
请注意添加 到默认环境变量将会影响你的系统中的所有 Python 3.7+ 应用。 如果你有任何 Python 3.7+ 应用仍然依赖于传统的系统编码格式,则推荐设置临时环境变量或使用 命令行选项。
用于Windows的Python启动器是一个实用程序,可帮助定位和执行不同的Python版本。它允许脚本(或命令行)指示特定Python版本的首选项,并将定位并执行该版本。
与 变量不同,启动器将正确选择最合适的Python版本。它更倾向于按用户安装而不是系统安装,并按语言版本排序,而不是使用最新安装的版本。
启动器最初是在 中指定的。
从命令行
全局安装Python 3.3及更高版本将把启动器放在你的 上。启动程序与所有可用的Python版本兼容,因此安装哪个版本无关紧要。要检查启动程序是否可用,请在命令提示符中执行以下命令:
您应该会发现已安装的最新版本的Python已启动 - 它可以正常退出,并且将指定的任何其他命令行参数直接发送到Python。
如果您安装了多个版本的Python(例如,2.7和 3.8 ),您会注意到Python 3.8 启动 - 如果要启动Python 2.7,尝试命令:
如果您想使用 Python 2.x 的最新版本,请尝试以下命令:
你会发现Python 2.x 的最新版本已启动。
如果您看到以下错误,则表明您没有安装启动器:
除非在安装时选择了该选项,单个用户安装的Python不会将启动程序添加到 。
从虚拟环境
如果启动程序运行时没有明确的Python版本,并且虚拟环境(使用标准库创建 模块或外部 工具)处于活动状态,则启动程序将运行虚拟环境的解释器而不是全局的。要运行全局解释器,请停用虚拟环境,或显式指定全局Python版本。
从脚本
让我们创建一个测试Python脚本 - 创建一个名为 的文件,其中包含以下内容
从hello.py所在的目录中,执行以下命令:
您应该注意到最新的Python 2.x安装的版本号已打印出来。现在尝试将第一行更改为:
现在,重新执行该命令应该打印最新的Python 3.x信息。与上面的命令行示例一样,你可以更明确的指定版本限定符。假设您安装了Python 2.6,请尝试将第一行更改为 ,你会发现打印的2.6版本信息。
请注意,与交互式使用不同,裸“python”将使用您已安装的Python 2.x的最新版本。这是为了向后兼容及兼容Unix,其中命令 通常是指Python 2。
从文件关联
安装时应该将启动器与Python文件(即 , , 文件)相关联。这意味着当您从Windows资源管理器中双击其中一个文件时,将使用启动程序,因此您可以使用上述相同的工具让脚本指定应使用的版本。
这样做的主要好处是,单个启动程序可以同时支持多个Python版本,具体取决于第一行的内容。
如果脚本文件的第一行以 开头,则称为 "shebang" 行。Linux和其他类Unix操作系统都有对这些行的本机支持,它们通常在此类系统上用来指示应该如何执行脚本。这个启动器允许在Windows上对Python脚本使用相同的工具,上面的示例演示了它们的使用。
为了允许Python脚本中的shebang行在Unix和Windows之间移植,该启动器支持许多“虚拟”命令来指定要使用的解释器。支持的虚拟命令是:
例如,如果脚本开始的第一行为
将找到并使用默认的Python。因为在Unix上编写的许多Python脚本已经有了这一行,你应该发现这些脚本可以由启动器使用而无需修改。如果您在Windows上编写一个新脚本,希望在Unix上有用,那么您应该使用以 开头的一个shebang行。
任何上述虚拟命令都可以显式指定版本(可以仅为主要版本,也可以为主要版本加次要版本)作为后缀。 此外,可以通过在次要版本之后添加 “-32” 来请求 32 位版本。 例如 将请求使用 32 位 python 2.7。
shebang line的 形式还有一个特殊属性。在寻找已安装的Python解释器之前,此表单将搜索可执行文件 以获取Python可执行文件。这对应于Unix中 程序的行为,该程序将在 执行搜索。
shebang 行还可以指定要传递给Python解释器的其他选项。 举例来说,如果你有这样的 shebang 行:
那么 Python 将以 选项启动
通过INI文件自定义
启动程序将搜索两个.ini文件 - 在当前用户的 "application data" 目录中搜索 (即通过使用 调用Windows函数 返回的目录)以及与启动器位于同一目录中的 。相同的.ini文件既用于启动器的“控制台”版本(即 py.exe),也用于“windows”版本(即pyw.exe)
“应用程序目录”中指定的自定义优先于可执行文件旁边.ini文件的自定义,因此对启动程序旁边的.ini文件不具有写访问权限的用户可以覆盖该全局.ini文件中的命令。
自定义默认的Python版本
在某些情况下,可以在命令中包含版本限定符,以指定命令将使用哪个Python版本。版本限定符以主版本号开头,可以选择后跟 ('.') 和次版本说明符。此外,可以通过添加 "-32" 或 “-64” 来指定是请求32位还是64位实现。
例如,一个shebang 行的 行没有版本限定符,而 有一个版本限定符,它只指定一个主版本。
如果在命令中找不到版本限定符,则可以设置环境变量 以指定默认版本限定符。 如果未设置,则默认为 "3"。 该变量可以指定能通过命令行传递的任何值,比如 "3", "3.7", "3.7-32" 或 "3.7-64"。 (请注意 "-64" 选项仅适用于 Python 3.7 或更高版本中包含的启动器。)
如果没有找到次版本限定符,则可以设置环境变量 (其中 是上面确定的当前主要版本限定符)以指定完整版本。如果没有找到这样的选项,启动器将枚举已安装的Python版本并使用为主要版本找到的最新次要版本,尽管不能保证,但该版本可能是该系列中最新安装的版本。
在安装了相同(major.minor)Python版本的32位和64位的64位Windows上,64位版本将始终是首选。对于启动程序的32位和64位实现都是如此 -- 这对于启动程序32位和64位都是正确的 -- 如果可用,32位启动程序将倾向于执行指定版本的64位Python安装。这样就可以预测启动器的行为,只知道PC上安装了哪些版本,而不考虑它们的安装顺序(即,不知道32位或64位版本的Python和相应的启动器是否是最后安装)。如上所述,可以在版本说明符上使用可选的“-32”或“-64”后缀来更改此行为。
示例:
除环境变量外,还可以在启动程序使用的.INI文件中配置相同的设置。 INI文件中的部分称为 ,键名称将与没有前导 前缀的环境变量相同(并注意INI文件中的键名不区分大小写) 。)环境变量的内容将覆盖INI文件中指定的内容。
例如:
如果设置了环境变量 (任何值),启动器将诊断信息打印到stderr(即:控制台)。虽然这些信息同时具有冗长 和 简洁性,但它应该允许您查看Python的版本、选择特定版本的原因以及用于执行目标Python的确切命令行。
Python通常将其库(以及您的site-packages文件夹)存储在安装目录中。因此,如果您已将Python安装到 ,则默认库将驻留在 中,第三方模块存储在 。
若要完全覆盖 ,请创建与DLL()或可执行文件(“python._pth`”)同名的 文件,并为要添加的每个路径指定一行 。基于DLL名称的文件覆盖基于可执行文件的文件,如果需要,可以为加载运行时的任何程序限制路径。
当文件存在时,将忽略所有注册表和环境变量,启用隔离模式,并且:除非文件中的一行指定 ,否则不会导入 。以 开头的空白路径和行将被忽略。每个路径可以是绝对的或相对于文件的位置。不允许使用除 以外的导入语句,并且不能指定任意代码。
请注意,当指定 时, 文件(没有前导下划线)将由 模块正常处理。
当找不到 文件时, 是如何在Windows上填充的:
如果在主可执行文件旁边或在可执行文件上一级的目录中找到 文件,则以下变体适用:
这一切的最终结果是:
对于那些想要将Python捆绑到其应用程序或发行版中的人,以下建议将防止与其他安装冲突:
这些将确保系统范围安装中的文件不会优先于与应用程序捆绑在一起的标准库的副本。否则,用户可能会在使用您的应用程序时遇到问题请注意,第一个建议是最好的,因为其他建议可能仍然容易受到注册表和用户站点包中的非标准路径的影响。
尽管Python的目标是在所有平台中都可移植,但是Windows有一些独特的特性。在标准库和外部都有一些模块和代码片段在使用这些特性。
特定于Windows的标准模块记录在 中。
Mark Hammond 的 模块是一组用于高级Windows特定支持的模块。这包括以下实用程序:
是PyWin32附带的一个示例MFC应用程序。它是一个内置调试器的可嵌入IDE。
是一个 的扩展 (参见 ),它将 Python 脚本包装成可执行的 Windows 程序 ( 文件)。 完成此操作后,你就可以分发你的应用程序而无需用户安装 Python。
由于Python的高级终端处理层 仅限于类Unix系统,因此Windows还有一个独立的库:用于Python的Windows 控制台 I/O .
是Turbo-C的 装饰器,用于创建文本用户界面。
如果你想自己编译CPython,首先要做的是获取 . 。您可以下载最新版本的源代码,也可以重新签出 . 。
源代码树包含Microsoft Visual Studio 2015的构建解决方案和项目文件,它是用于构建官方Python版本的编译器。这些文件位于 目录中。
检查 以获取有关构建过程的一般信息。
有关扩展模块,请参阅 。
随着Python的不断发展,不再支持以前曾经支持的一些平台(由于缺少用户或开发人员)。检查 了解所有不支持的平台的详细信息。
有关具有预编译安装程序平台的详细信息,请参阅
版权声明:
本文来源网络,所有图片文章版权属于原作者,如有侵权,联系删除。
本文网址:https://www.mushiming.com/mjsbk/8447.html