windows下Python2与Python3共存的使用方法以及pip的使用方法以及pip安装报错:is not a supported wheel on this platform的处理方法

本文介绍如何在同一系统中共存并区分使用Python2和Python3,包括使用py.exe启动器选择Python版本、通过文件首行注释指定解释器以及使用pip安装不同版本Python的包。

http://blog.youkuaiyun.com/u012318074/article/details/52411005


pip针对不同版本的使用方法:

官方的解法是什么?
事实上这个问题几年以前Python社区就给出了官方解决方案,只不过国内一直没有注意到罢了。我们在安装Python3(>=3.3)时,Python的安装包实际上在系统中安装了一个启动器py.exe,默认放置在文件夹C:\Windows\下面。这个启动器允许我们指定使用Python2还是Python3来运行代码(当然前提是你已经成功安装了Python2和Python3)。
有关Python2和3的安装,可以参见
Python部落(http://python.freelycode.com)-->影音学堂-->《0基础1小时,Python入门》的第一节。

py的用法
如果你有一个Python文件叫 hello.py,
那么你可以这样用Python2运行它py -2 hello.py类似的,
如果你想用Python3运行它,就这样py -3 hello.py
去掉参数 -2/-3每次运行都要加入参数-2/-3还是比较麻烦,所以py.exe这个启动器允许你在代码中加入说明,表明这个文件应该是由python2解释运行,还是由python3解释运行。说明的方法是在代码文件的最开始加入一行#! python2或者#! python3分别表示该代码文件使用Python2或者Python3解释运行。这样,运行的时候你的命令就可以简化为py hello.py
使用pip
当Python2和Python3同时存在于windows上时,它们对应的pip都叫pip.exe,所以不能够直接使用 pip install 命令来安装软件包。而是要使用启动器py.exe来指定pip的版本。
命令如下:py -2 -m pip install XXXX-2 还是表示使用 Python2,-m pip 表示运行 pip 模块,也就是运行pip命令了。
如果是为Python3安装软件,那么命令类似的变成py -3 -m pip install XXXX
#! python2 和 # coding: utf-8 哪个写在前面?对于Python2用户还有另外一个困惑,Python2要在代码文件顶部增加一行说明,才能够在代码中使用中文。如果指明使用的Python版本也需要在文件顶部增加一行,那哪一行应该放在第一行呢?#! python2 需要放在第一行,编码说明可以放在第二行。所以文件开头应该类似于:#! python2
# coding: utf-8
有了这些技巧,Python2和Python3就可以愉快地在一起玩耍了~

确实,我最初听从某网站建议,把python2.7的python.exe改成了python2.exe以便于区分,但是后果就是使用pip模块时报错
改回到python.exe之后,使用py -2 -m pip install XX就成功了。记得把python2的路径加入到环境变量中去

使用 `pip` 安装 `.whl` 文件时,遇到错误 `is not a supported wheel on this platform` 通常表示当前环境所下载的 wheel 文件不兼容。该问题主要涉及 Python 版本、操作系统平台以及构建环境之间的匹配性。以下是详细解决方案: ### 1. 检查 Python 版本和平台兼容性 每个 `.whl` 文件名称中包含特定的标识符,用于说明其支持的 Python 版本和平台。例如: - `cp38` 表示 CPython 3.8。 - `win_amd64` 表示适用于 Windows 64 位系统。 确保下载的 wheel 文件当前 Python 版本和操作系统平台匹配。可以通过以下命令查看 Python 版本和平台信息: ```python import sys print(sys.version) print(sys.platform) ``` ### 2. 使用 `pip debug --verbose` 检查支持的 wheel 格式 运行以下命令以查看当前环境中支持的 wheel 格式: ```bash pip debug --verbose ``` 输出结果中会列出支持的标签(Tags),例如 `cp38`, `cp37`, `win_amd64` 等。下载的 `.whl` 文件必须这些标签匹配。 ### 3. 从官方或可信源下载 wheel 文件 如果官方 PyPI 仓库中未提供特定包,可以从以下可信源下载: - [Unofficial Windows Binaries for Python Extensions](https://www.lfd.uci.edu/~gohlke/pythonlibs/) 提供了许多常用库的 wheel 文件,例如 `Twisted` 和 `opencv-python` [^2]。 - 确保选择当前 Python 版本和平台完全匹配的文件。 ### 4. 使用虚拟环境管理依赖 如果 Python 版本 wheel 文件不匹配,可以尝试创建一个目标 wheel 文件兼容的虚拟环境。例如: ```bash python -m venv myenv source myenv/bin/activate # Linux/macOS myenv\Scripts\activate # Windows ``` 在虚拟环境中安装兼容版本的 Python 和依赖库。 ### 5. 编译源代码或使用替代包 如果无法找到匹配的 wheel 文件,可以尝试从源码安装: ```bash pip install some-package --no-binary :all: ``` 或者,使用替代包管理工具,如 `conda`,它能够更好地处理平台和依赖问题: ```bash conda install -c conda-forge some-package ``` ### 6. 避免使用不兼容的 Python 实现 某些 wheel 文件仅支持特定的 Python 实现(如 CPython)。如果使用了其他实现(如 PyPy),可能会导致不兼容问题。确保使用的是标准的 CPython 环境 [^1]。 ### 7. 更新 pip 和 setuptools 确保 `pip` 和 `setuptools` 是最新版本,以支持最新的 wheel 格式: ```bash python -m pip install --upgrade pip setuptools ``` ### 示例:安装 Twisted 的兼容版本 假设当前环境为 Python 3.8 和 Windows 64 位系统,可以下载 `Twisted-20.3.0-cp38-cp38-win_amd64.whl` 并运行以下命令安装: ```bash pip install Twisted-20.3.0-cp38-cp38m-win_amd64.whl ``` 如果报错 `is not a supported wheel on this platform`,请检查当前 Python 版本是否为 3.8 并且平台是否为 64 位 Windows 。 ---
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值