[python]pip换源详解

前言

现有的各个网站上的pip换源方式,很零散,或者是很单调的重复,又或者只是给出命令,尽管这通常就够用了。

但是,我希望汇总一下,然后再结合pip的官方文档来做一些补充。

因为,换源是一个很基础的操作,很多操作,久了不用的话,也很容易忘,所以总结一下,也是很有意义的。

目前本文章仅仅涉及Windows​环境下的操作,暂未包括其他系统下的换源操作。


目录

@


了解pip配置文件

配置文件

  • global​:系统范围的配置文件,在用户之间共享
  • user​:每个用户的配置文件
  • site​:每个环境的配置文件,i.e. per-virtualenv


对应级别的配置文件在对应的系统的所在路径

Windows:

  • Global

    • 在Windows 7 及以上版本:(隐藏但可写)C:\ProgramData\pip\pip.ini
    • Windows Vista:不支持全局配置
    • Windows XP:C:\Documents and Settings\All Users\Application Data\pip\pip.ini
  • User​(笔者试验后只有此文件)

    • %APPDATA%\pip\pip.ini
    • C:\Users\Administrator\AppData\Roaming\pip\pip.ini
    • 还会加载旧版“每个用户”的配置文件(如果存在):%HOME%\pip\pip.ini
  • Site

    • %VIRTUAL_ENV%\pip.ini
  • PIP_CONFIG_FILE

    • 环境变量可以指定最后加载的配置文件,其值将覆盖上述文件中设置的值。
    • os.devnull​中设置它,可以禁用所有的配置文件,如果设置的位置已经存在该文件,用户的配置文件不会被加载


配置文件加载顺序

如果pip找到多个配置文件,pip会按照下面的次序加载它们:

  • Global
  • User
  • Site
  • PIP_CONFIG_FILE​, 如果存在该文件

每次加载配置文件,都会覆盖从之前加载的文件中读取的任何值,例如,在全局(global)设置中和用户(User)设置中,如果都设置了timeout​的数值,那么pip会使用后者(User)的值。


命令选项配置

配置文件内的命名都派生于命令行长选项。

比如,如果你想使用一个不同的包索引--index-url​,并且将HTTP​超时设置为60秒--default-timeout​,那么你的配置文件将如下所示:

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

每个子命令都可以在其自己的部分中选择配置,而这将会覆盖具有相同名称的全局设置

例如,如果你在运行pip freeze​时希望减少秒数为10秒,并且为所有其他的命令使用减少后的秒数:

[global]
timeout = 60 [freeze]
timeout = 10

对于布尔选项的设置,如--ignore-installed​ 或者 --no-dependencies​可以像这样设置:

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

如果要启用布尔选项--no-compile​, --no-warn-script-location​ 和 --no-cache-dir​必须使用假值(false​|no​):

[global]
no-cache-dir = false [install]
no-compile = no
no-warn-script-location = false

可重复选项的选项,如--verbose​ 和 --quiet​,一个非负整数可以被用来代表被指定的级别:

[global]
quiet = 0
verbose = 2

给在配置文件里的部分添加值时有可能的。给可以被写在多行中的选项如--find-links​ 或者 --trusted-host​添加数值是被允许的。

这就使得用户能够按照命令行参数加入的顺序附加参数

[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

可以使用格式化的PIP_<UPPER_LONG_NAME>​来设置pip命令行选项的环境变量,破折号-​必须被下划线_​替代:

  • PIP_DEFAULT_TIMEOUT=60​ 等同于 --default-timeout=60

  • PIP_FIND_LINKS="http://mirror1.example.com http://mirror2.example.com"​ 等同于 --find-links=http://mirror1.example.com --find-links=http://mirror2.example.com

  • 没有数值的可重复选项(例如--verbose​ )可以通过使用重复的数值来指定数值

    PIP_VERBOSE=3​ 等同于 pip install -vvv

    注意:

    设置空字串的环境变量不能被视为假值,使用no​,false​,0​来替代

命令行选项覆盖环境变量,环境变量覆盖配置文件中的值。在配置文件中,命令特定部分的值覆盖全局部分的值。

  • --host=foo​ 覆盖 PIP_HOST=foo
  • PIP_HOST=foo​ 覆盖配置文件中的 [global] host = foo
  • 在配置文件中的一个命令的特定部分 [<command>] host = bar​ 覆盖在配置文件部分[global]​ 中的同名选项.


配置方式

法一:直接打开配置文件进行编辑

直接打开%APPDATA%\pip\pip.ini​(C:\Users\Administrator\AppData\Roaming\pip\pip.ini​),然后对其进行编辑。

-i​,--index-url <url>​ :

Python包索引的基本URL(默认为https://pypi.org/simple)。这应该指向符合PEP 503(简单存储库API)的存储库或以相同格式布局的本地目录。

--extra-index-url <url>​:

除了--index-url​之外要使用的包索引的额外url。应该遵循与--index-url​相同的规则。

-f​,--find-links <url>​:

如果是html文件的URL或路径,那么解析到归档文件的链接,例如sdist (.tar.gz)或wheel (.whl)文件。如果本地路径或file:// URL是一个目录,那么在目录列表中查找存档。不支持VCS项目url的链接。

--trusted-host <hostname>​:

将此主机或(主机:端口)标记为受信任,即使它是无效的链接或任何HTTPS。

根据前面的命令选项配置部分,我们可以在配置文件里设置参数(包索引的基本URL和包索引的额外URL)的数值,从而实现换源。

示例为pip多源配置:

[global]
index-url = http://mirrors.aliyun.com/pypi/simple/
extra-index-url =
https://pypi.mirrors.ustc.edu.cn/simple/
http://pypi.douban.com/simple/
https://pypi.tuna.tsinghua.edu.cn/simple/
http://pypi.mirrors.ustc.edu.cn/simple/
https://pypi.org/simple
[install]
trusted-host=
mirrors.aliyun.com
pypi.mirrors.aliyun.com
pypi.douban.com
pypi.tuna.tsinghua.edu.cn
pypi.mirrors.ustc.edu.cn

法二:通过命令设置

使用pip config set​命令,直接设置相关命令选项的数值

py -m pip config [<file-option>] list
py -m pip config [<file-option>] [--editor <editor-path>] edit
py -m pip config [<file-option>] get command.option
py -m pip config [<file-option>] set command.option value
py -m pip config [<file-option>] unset command.option
py -m pip config [<file-option>] debug

  • list:列出活动的配置(或者从指定的文件)
  • edit:在编辑器里面编辑配置文件
  • get:获得和命令选项相关的数值
  • set:设置命令选项的数值
  • unset:取消设置命令选项的数值
  • debug:列出配置文件和在它们中定义的数值

  • pip config set global.index-url https://pypi.tuna.tsinghua.edu.cn/simple​:

    设置配置文件global​的index-url​的数值为https://pypi.tuna.tsinghua.edu.cn/simple

    也就是,设置你的Python包索引的基本URL为https://pypi.tuna.tsinghua.edu.cn/simple

    这也就是我们常说的换源操作。

  • pip config set global.extra-index-url "<url1> <url2>..."​:

    如果说,你想要设置备用源的话(其他几个国内镜像源,以及以防万一的,默认的源https://pypi.org/simple),那么你需要这个命令。

    其中<url1>​和<url2>​指的是你需要设置的备用源的URL地址,它们之间需要用空格隔开。

    这也就是我们设置的多个备用源的操作

  • pip config set install.trusted-host pypi.tuna.tsinghua.edu.cn​:

    这条命令的作用在前面提到过,标记主机或者主机:端口为信任。

    当你选用了非默认源后,似乎通常需要设置非默认源为信任。

    如果不设置会怎样,笔者暂时未尝试过。

参考资料

[python]pip换源详解的更多相关文章

  1. Python pip换源

    前言 哈喽呀,小伙伴们,晚上好呀,今天要给大家带来点什么呐,我们就来说说python的pip换源吧,这个换源,相对来说,还是比较重要的,能少生好几次气的,哈哈哈 为什么要换源 我们搞python的,肯 ...

  2. python pip 换源

    title: pip 换源 author: 杨晓东 permalink: pip-换源 date: 2021-10-02 11:27:04 categories: - 投篮 tags: - demo ...

  3. [Python]Pip换源以及设置代理

    Install python package with proxy sudo pip install python-magic --proxy=https://your-proxy.com 2.No ...

  4. python pip换源方法

    以下资料来源于网络: pip国内的一些镜像   阿里云 http://mirrors.aliyun.com/pypi/simple/   中国科技大学 https://pypi.mirrors.ust ...

  5. python虚拟环境 + 批量pip + 换源

    python虚拟环境 + 批量pip + 换源 虚拟环境 曾经我是一个小白,不管运行什么项目都用一个环境,后来项目多了,有的是Django1.11的有的是Django2的,有的项目只能在3.6上运行, ...

  6. pip安装使用详解【转】

    转自:pip安装使用详解 – 运维生存时间http://www.ttlsa.com/python/how-to-install-and-use-pip-ttlsa/ pip类似RedHat里面的yum ...

  7. python之OS模块详解

    python之OS模块详解 ^_^,步入第二个模块世界----->OS 常见函数列表 os.sep:取代操作系统特定的路径分隔符 os.name:指示你正在使用的工作平台.比如对于Windows ...

  8. Python对Excel操作详解

      Python对Excel操作详解 文档摘要: 本文档主要介绍如何通过python对office excel进行读写操作,使用了xlrd.xlwt和xlutils模块.另外还演示了如何通过Tcl   ...

  9. Python的logging模块详解

          Python的logging模块详解 作者:尹正杰  版权声明:原创作品,谢绝转载!否则将追究法律责任. 一.日志级别 日志级别指的是产生的日志的事件的严重程度. 设置一个级别后,严重程度 ...

  10. Python解释器换源

    Python解释器换源 """ 1.采用国内源,加速下载模块的速度 2.常用pip源: -- 豆瓣:https://pypi.douban.com/simple -- 阿 ...

随机推荐

  1. Qt编写地图综合应用59-经纬度坐标纠偏

    一.前言 地图应用中都涉及到一个问题就是坐标纠偏的问题,这个问题的是因为根据地方规则保密性要求不允许地图厂商使用标准的GPS坐标,而是要用国家定义的偏移标准,或者在此基础上再做算法运算,所以这就出现了 ...

  2. IM开发快速入门(二):什么是IM系统的实时性?

    本文在编写时参考了博客作者"鹿呦呦"和在线课程"即时消息技术剖析与实战"的相关资料,一并表示感谢. 1.引言 随着移动互联网络的发展,IM技术的应用已经不仅限于 ...

  3. 开源轻量级 IM 框架 MobileIMSDK v6.1.2 发布!

    一.更新内容简介 本次更新为次要版本更新,进行了若干优化(更新历史详见:码云 Release Nodes).可能是市面上唯一同时支持 UDP+TCP+WebSocket 三种协议的同类开源IM框架. ...

  4. 一套十万级TPS的IM综合消息系统的架构实践与思考

    本文由作者jhon_11分享,有大量修订和改动. 1.引言 如何设计一款高性能.高并发.高可用的im综合消息平台是很多公司发展过程中会碰到且必须要解决的问题.比如一家公司内部的通讯系统.各个互联网平台 ...

  5. .NET Core + Kafka 开发指南

    什么是Kafka Apache Kafka是一个分布式流处理平台,由LinkedIn开发并开源,后来成为Apache软件基金会的顶级项目.Kafka主要用于构建实时数据管道和流式应用程序. Kafka ...

  6. 在 Vercel 部署随机图 API

    在本文中,将详细介绍如何在 Vercel 平台上部署一个具有分类功能的随机图片 API.通过这个 API,用户可以根据不同的分类获取随机图片链接,并且还可以从所有分类中随机获取一张图片. 项目结构 首 ...

  7. [转载]「服务」WCF中NetNamedPipeBinding的应用实例

    「服务」WCF中NetNamedPipeBinding的应用实例 WCF中有很多种绑定,根据官方的说法,NetNamedPipeBinding是适用于同一台主机中不同进程之间的通信的. 今天终于实现了 ...

  8. 文章学习 | MPC 是下一代私钥安全的7大原因

    文章学习:MPC 是下一代私钥安全的7大原因 前言 多重签名钱包与单一密钥钱包相比,因其提升了资产安全性,如今已成为机构管理加密货币的标准做法.然而,最近在多方计算(MPC)领域的密码学突破正引领私钥 ...

  9. 平滑升级mariadb

    问题 Centos7自带的MariaDB版本是5.5 ,版本过于老旧,现想升级到最新版本,且数据不丢失 措施 备份原来的数据 mysqldump -u root -p --all-databases ...

  10. 迁移polardb问题一

    环境 polardb版本 <dependency> <groupId>com.aliyun</groupId> <artifactId>polardb- ...