Python3 For Windows 10

installer

参考 The full installer

安装

Win10 安装 Python3 (上)_Python3

Win10 安装 Python3 (上)_Python3 _02

Win10 安装 Python3 (上)_Python3 _03

Win10 安装 Python3 (上)_Python3 _04

Win10 安装 Python3 (上)_Python3 _05

Win10 安装 Python3 (上)_Python3 _06

Win10 安装 Python3 (上)_Python3 _07

随后可以看到,installer 在用户环境变量PATH中,添加了三项:
Win10 安装 Python3 (上)_Python3 _08

卸载

使用 installer 卸载 python 时,并不会移除 launcher。若要移除 launcher,需要打开“程序和功能”,在列表中选择删除。同时,python 也可以通过这里删除或修改。

简单配置

参考 Configuring Python

UTF-8 mode

两种方式:

  • 设置环境变量 PYTHONUTF8 为 1;
  • 在命令行中传递参数 -X utf8

即使该模式未开启,在下面两种情况下,仍将使用 UTF-8:

  • Console I/O including standard I/O
  • The filesystem encoding

Python Launcher

参考 Python Launcher for Windows

一个用于选择和执行不同版本 Python 的实用程序。

虚拟环境

如果没有显式给出 Python 版本,且激活了虚拟环境(由标准库 venv 模块或外部的 virtualenv 工具创建),那么 launcher 将使用虚拟环境中的解释器,而非全局的。

文件关联

.py, .pyw, .pyc

只有安装了 launcher,才会产生这些关联。这意味着,我们可以双击执行一个脚本文件,而不用打开命令行。

Shebang Lines

这个东西在 Nix 系统上是原生支持的,而在 Windows 上,由 launcher 来提供这一支持。

虽然很奇怪,但

#!/usr/bin/python

将启用默认的 Python 版本,当然,也可以显式地添加版本后缀,以启用其它版本。

使用 /usr/bin/env 形式的 shebang 将会在 PATH 中搜索 Python 可执行文件,其行为,就如同 Nix 中的 env 程序一样。

此外,也可以在 shebang 中向解释器传递一些选项。

Customization

INI

  • 在%appdata%(当前用户的应用数据目录)中的 py.ini;(高优先级)
  • launcher 所在目录下的 py.ini。

Finding modules

参考 Finding modules

Python 通常将它的库放在安装目录下,默认的库位于 {root}\Lib\,第三方库位于 {root}\Lib\site-packages\。

._pth 和 .pth 文件

pyvenv.cfg 文件

Pip

config

参考 pip configConfiguration

子命令:

  • list
  • edit
    • 需要使用 --editor 指定所用编辑器,否则使用变量 VISUAL 或 EDITOR 指定。
    • 很奇怪的是,传入 VScode 的路径,总是报错,而使用 notepad 却没有问题。
  • get
  • set
  • unset
  • debug

作用域选项:

OptionsDescriptionsLocations
--globalUse the system-wide configuration file onlyC:\ProgramData\pip\pip.ini
--userUse the user configuration file only
--siteUse the current environment configuration file only

file

位置
Per-user
  • Default is %appdata%\pip\pip.ini;
  • 由于历史原因,%home%\pip\pip.ini也会被考虑;
  • 当然,也可以自定一个位置,设置环境变量 PIP_CONFIG_FILE 即可。
Inside a virtualenv

%virtual_env%\pip.ini

Global

C:\ProgramData\pip\pip.ini

哪一个

如果发现有多个配置文件,那么按以下顺序进行读取,且后者覆盖前者:

  • global
  • per-user
  • virtualenv-specific
怎么写

The names of the settings are derived from the long command line option, e.g. if you want to use a different package index (--index-url) and set the HTTP timeout (--default-timeout) to 60 seconds your config file would look like this:

[global]
timeout = 60
index-url = https://download.zope.org/ppix

Each subcommand can be configured optionally in its own section so that every global setting with the same name will be overridden; e.g. decreasing the timeout to 10 seconds when running the freeze (pip freeze) command and using 60 seconds for all other commands is possible with:

[global]
timeout = 60

[freeze]
timeout = 10

Boolean options like --ignore-installed or --no-dependencies can be set like this:

[install]
ignore-installed = true
no-dependencies = yes

To enable the boolean options --no-compile, --no-warn-script-location and --no-cache-dir, falsy values have to be used:

[global]
no-cache-dir = false

[install]
no-compile = no
no-warn-script-location = false

For options which can be repeated like --verbose and --quiet, a non-negative integer can be used to represent the level to be specified:

[global]
quiet = 0
verbose = 2

It is possible to append values to a section within a configuration file such as the pip.ini file. This is applicable to appending options like --find-links or --trusted-host, which can be written on multiple lines:

[global]
find-links =
    http://download.example.com

[install]
find-links =
    http://mirror1.example.com
    http://mirror2.example.com

trusted-host =
    mirror1.example.com
    mirror2.example.com

This enables users to add additional values in the order of entry for such command line arguments.

环境变量

pip’s command line options can be set with environment variables using the format PIP_ . Dashes (-) have to be replaced with underscores (_).

优先级

命令行参数>环境变量>配置文件

aboutMe

配置了一下镜像源:

> pip config --global set global.index-url https://mirrors.bfsu.edu.cn/pypi/web/simple

这将创建全局配置文件,并写入。

随后我直接在该文件中添加了一些配置项:

[global]
index-url = https://mirrors.bfsu.edu.cn/pypi/web/simple
cache-dir = D:\xxxxx\Documents\Python\pip\cache

注意,虽然看起来 cache-dir 像是和 cache 命令相关的,但实际上它是一个通用选项(General Options),而非 Cache Options,所以,如果将其放在 [cache] 下,将不会产生任何效果。

virtualenv

参考 Virtualenv

Creators

venv

可将创建行为委托给 Python 标准库中的 venv 模块。virtualenv 将创建一个进程来调用该模块,这在 Windows 上将是一笔不小的开销。

builtin

virtualenv 本身便可以执行创建操作。

Seeders

种包指的是 pip,setuptools,wheel 三者中的一或多个。安装种包,将使得你可以在创建的虚拟环境中安装其它的包。对于种包的安装,有两种机制:

pip

使用与 virtualenv 绑定的 pip 安装种包,这将创建一个进程来执行之。

add-data

在用户应用数据目录下创建一个安装镜像,随后要用到时,只需要简单的链接或拷贝这些镜像即可。对 Windows 来说,可能没有使能 symlink,但即便是拷贝,也快得多了。

可以使用环境变量 VIRTUALENV_OVERRIDE_APP_DATA 指定 the seed cache 的位置。

Activators

在虚拟环境目录下,Scripts文件夹中,有一些激活脚本。它们被用来修改 shell 的设置,以确保虚拟环境中的命令要优先于全局路径下的。

CLI interface

virtualenv 主要是一个命令行应用。默认的命令行标志可以被配置文件覆盖,而环境变量又优先于配置。使用 --help 时,可以在帮助信息的最后看到该标志的值,以及是否默认。

OptionsDefaultDescription
--app-data平台相关(win10 中为 %localappdata%\pypa\virtualenva data folder used as cache by the virtualenv
--read-only-app-dataFalse以只读模式使用 app data 文件夹
--reset-app-dataFalse移除 app data 文件夹(即使没有传递必需的 dest)
--upgrade-embed-wheelsFalse手动升级内置的 wheels(注意,这个不是特指用于种包的那个 wheel 包)
-p, --python安装时使用的 python 可执行版本使用哪个 python 可执行文件来创建环境
--creatorbuiltin if exist, else venv用于创建环境的执行者
dest
要在哪里创建
--clearFalse如果目标目录不为空,清除之
--no-vcs-ignoreFalse不要在目标目录下创建 VCS 忽略文件(如 .gitignore
--system-site-packagesFalse使得虚拟环境可以访问到全局的 site-packages
--symlinksTrue可以 symlink,就不 copy
--copies, --always-copyFalse总是 copy
--seederapp-data种包的安装方式。若选择 pip,则很多选项将无意义
--no-seed, --without-pipFalse不安装种包
--no-download, --never-downloadTrue不要从 PyPI 上下载最新的种包
--downloadFalse从 PyPI 上下载最新的种包使用
--pip, --setuptools, --wheelbundle种的版本,默认为与 virtualenv 绑定的那个,否则使用指定的版本(所谓“绑定”,即为“内置”)
--no-pip, --no-setuptools, --no-wheelFalse不安装种包
--no-periodic-updateFalse不对内置的 wheels 进行周期性(14天)更新
--symlink-app-dataFalse从 app data 中符号链接 python 包
--activators全部要生成哪些激活器:bash, batch, cshell, fish, powershell, python, xonsh
--prompt(venv_name)为该环境指定一个提示符前缀

Configuration file

位置

和 pip 一样,virtualenv 也使用标准的 ini 格式的配置文件,默认为 %localappdata%\pypa\virtualenv\virtualenv.ini。

在 --help 输出的最后,可以看到配置文件的位置。可使用 VIRTUALENV_CONFIG_FILE 自定义其位置。

怎么写

基于命令行选项,将左边的 - 符号移除,使用 _ 替换 - 即可配置之。

aboutMe
[virtualenv]

app_data = D:\xxxxx\Documents\Python\pypa\virtualenv

no_vcs_ignore = true

system_site_packages = true

no_periodic_update = true

activators = batch

Misc

  • venv — Creation of virtual environments

Note: While symlinks are supported on Windows, they are not recommended. Of particular note is that double-clicking python.exe in File Explorer will resolve the symlink eagerly and ignore the virtual environment.

The created pyvenv.cfg file also includes the include-system-site-packages key, set to true if venv is run with the --system-site-packages option, false otherwise.

When a virtual environment is active, the VIRTUAL_ENV environment variable is set to the path of the virtual environment. This can be used to check if one is running inside a virtual environment.

... However, all scripts installed in a virtual environment should be runnable without activating it, and run with the virtual environment’s Python automatically.

Note: A virtual environment is a Python environment such that the Python interpreter, libraries and scripts installed into it are isolated from those installed in other virtual environments, and (by default) any libraries installed in a “system” Python, i.e., one which is installed as part of your operating system.

A virtual environment is a directory tree which contains Python executable files and other files which indicate that it is a virtual environment.

Common installation tools such as setuptools and pip work as expected with virtual environments. In other words, when a virtual environment is active, they install Python packages into the virtual environment without needing to be told to do so explicitly.

When a virtual environment is active (i.e., the virtual environment’s Python interpreter is running), the attributes sys.prefix and sys.exec_prefix point to the base directory of the virtual environment, whereas sys.base_prefix and sys.base_exec_prefix point to the non-virtual environment Python installation which was used to create the virtual environment. If a virtual environment is not active, then sys.prefix is the same as sys.base_prefix and sys.exec_prefix is the same as sys.base_exec_prefix (they all point to a non-virtual environment Python installation).

When a virtual environment is active, any options that change the installation path will be ignored from all distutils configuration files to prevent projects being inadvertently installed outside of the virtual environment.

When working in a command shell, users can make a virtual environment active by running an activate script in the virtual environment’s executables directory (the precise filename and command to use the file is shell-dependent), which prepends the virtual environment’s directory for executables to the PATH environment variable for the running shell. There should be no need in other circumstances to activate a virtual environment; scripts installed into virtual environments have a “shebang” line which points to the virtual environment’s Python interpreter. This means that the script will run with that interpreter regardless of the value of PATH. On Windows, “shebang” line processing is supported if you have the Python Launcher for Windows installed (this was added to Python in 3.3 - see PEP 397 for more details). Thus, double-clicking an installed script in a Windows Explorer window should run the script with the correct interpreter without there needing to be any reference to its virtual environment in PATH.