【小技巧】PyCharm建立项目,VScode+CodeX+WindowsPowerShell开发Python pyQT6 (二)


你的报错栈关键信息是:

复制代码
ValueError: check_hostname requires server_hostname
...
urllib3.connection._connect_tls_proxy → ssl_wrap_socket(...)

这表示 pip 认为自己需要通过一个代理(HTTP/HTTPS_PROXY)连接 PyPI ,但该代理配置不规范(常见是写成 127.0.0.1:7890 没有协议头),触发了"TLS 套 TLS"时未提供 server_hostname 的错误。解决思路:要么禁用代理再装,要么把代理写成正确格式 http://host:port

下面给你一套"从排查→修正→验证"的详细步骤(PowerShell):


一步一步来

0. 进入你的项目目录(你已经在)

powershell 复制代码
cd C:\Users\xsshu\Desktop\Python\random_pro

1) 检查是否设置了代理(环境变量)

powershell 复制代码
Get-ChildItem Env: | ? { $_.Name -match 'proxy' }

如果输出里有 HTTP_PROXY / HTTPS_PROXY(大小写都算),说明 pip 正在走这个代理。

2) 先在"当前会话"里临时禁用代理

(最简单、风险最低)

powershell 复制代码
Remove-Item Env:HTTP_PROXY  -ErrorAction SilentlyContinue
Remove-Item Env:HTTPS_PROXY -ErrorAction SilentlyContinue

也可以一条命令在安装时显式禁用:--proxy=""(下面第 5 步会用到)

3) 检查 pip 的持久化配置里是否写了代理/镜像

pip 在 Windows 会读这些位置的配置:

  • 用户:%APPDATA%\pip\pip.ini
  • 全局:%PROGRAMDATA%\pip\pip.ini
  • 虚拟环境:.venv\pip.ini(少见)

逐个看看是否有 proxy = ...index-url = ...

powershell 复制代码
Get-Content $env:APPDATA\pip\pip.ini -ErrorAction SilentlyContinue
Get-Content $env:PROGRAMDATA\pip\pip.ini -ErrorAction SilentlyContinue

如看到 proxy= 且值是 127.0.0.1:7890 这种没有协议头 的,请改成 http://127.0.0.1:7890,或者直接先删掉这一行(禁用代理安装最稳)。

也可以用 pip 命令取消:

powershell 复制代码
.\.venv\Scripts\python.exe -m pip config list
.\.venv\Scripts\python.exe -m pip config unset global.proxy
# 如需改回官方源也可以:
# .\.venv\Scripts\python.exe -m pip config set global.index-url https://pypi.org/simple

4) 验证你的虚拟环境是 64 位(已验证 OK)

你已经确认:

复制代码
Python 3.9.6 / arch=64 / Windows 10

这满足 PyQt6 的轮子要求(win_amd64)。

5) 在禁用代理的前提下升级 pip 并安装包

任选其一(官方源或清华镜像),注意我加了 --proxy="" 强制忽略任何遗留代理:

用官方源:

powershell 复制代码
.\.venv\Scripts\python.exe -m pip install -U pip wheel setuptools --proxy="" -i https://pypi.org/simple
.\.venv\Scripts\python.exe -m pip install PyQt6 pyserial --proxy="" -i https://pypi.org/simple

或用清华镜像:

powershell 复制代码
.\.venv\Scripts\python.exe -m pip install -U pip wheel setuptools --proxy="" -i https://pypi.tuna.tsinghua.edu.cn/simple
.\.venv\Scripts\python.exe -m pip install PyQt6 pyserial --proxy="" -i https://pypi.tuna.tsinghua.edu.cn/simple

如果你在公司网络被 SSL 拦截导致证书不被信任,可以加上 --trusted-host

复制代码
.\.venv\Scripts\python.exe -m pip install -i https://pypi.tuna.tsinghua.edu.cn/simple --trusted-host pypi.tuna.tsinghua.edu.cn PyQt6 pyserial --proxy=""

6) 必须走代理时,把格式改正确再装

如果你确实需要代理,请务必带协议头(通常 http:// 即可):

powershell 复制代码
# 仅对当次会话生效的示例
$env:HTTP_PROXY  = "http://127.0.0.1:7890"
$env:HTTPS_PROXY = "http://127.0.0.1:7890"

.\.venv\Scripts\python.exe -m pip install -U pip -i https://pypi.org/simple
.\.venv\Scripts\python.exe -m pip install PyQt6 pyserial -i https://pypi.org/simple

不要 写成 127.0.0.1:7890(缺少 http://)或写成 https://127.0.0.1:7890(大多数本地代理只支持 HTTP CONNECT)。

如果想长期生效,可持久化:

powershell 复制代码
setx HTTP_PROXY  "http://127.0.0.1:7890"
setx HTTPS_PROXY "http://127.0.0.1:7890"
# 关闭并重新打开一个 PowerShell 窗口后生效

7) 安装完成后验证

powershell 复制代码
.\.venv\Scripts\python.exe -c "import PyQt6,serial; from PyQt6.QtWidgets import QApplication; print('PyQt6=',PyQt6.__version__)"

8) 兜底:离线安装(万一网络环境限制很严)

用浏览器下载与你环境匹配的三个 wheel(cp39、win_amd64):

  • PyQt6_sip-<ver>-cp39-cp39-win_amd64.whl
  • PyQt6_Qt6-<ver>-win_amd64.whl
  • PyQt6-<ver>-cp39-cp39-win_amd64.whl

然后在下载目录执行:

powershell 复制代码
.\.venv\Scripts\python.exe -m pip install .\PyQt6_sip-*.whl
.\.venv\Scripts\python.exe -m pip install .\PyQt6_Qt6-*.whl
.\.venv\Scripts\python.exe -m pip install .\PyQt6-*.whl
.\.venv\Scripts\python.exe -m pip install pyserial

一条命令"快捷修复"(禁用代理→升级 pip→安装)

如果你想快速试一次(官方源):

powershell 复制代码
$env:HTTP_PROXY=""; $env:HTTPS_PROXY="";
.\.venv\Scripts\python.exe -m pip install -U pip wheel setuptools --proxy="" -i https://pypi.org/simple && `
.\.venv\Scripts\python.exe -m pip install PyQt6 pyserial --proxy="" -i https://pypi.org/simple

执行完 5/7 步后再运行你的程序即可。若过程中任何一步仍抛同样错误,把命令返回完整粘给我,我直接帮你定位是哪一级代理还在生效。


安装已经成功了;现在这个报错是因为PyQt6 顶层没有 __version__ 属性,所以:

复制代码
AttributeError: module 'PyQt6' has no attribute '__version__'

用下面方式查询版本即可。

正确的版本查看方式

方式1:用 pip show

powershell 复制代码
.\.venv\Scripts\python.exe -m pip show PyQt6 PyQt6-Qt6 PyQt6-sip

会分别显示:

  • PyQt6(绑定包)版本
  • Qt6 运行库版本(PyQt6-Qt6)
  • SIP 版本(PyQt6-sip)

方式2:从 QtCore 里取(推荐)

powershell 复制代码
.\.venv\Scripts\python.exe - << 'PY'
from PyQt6.QtCore import PYQT_VERSION_STR, QLibraryInfo
print("PyQt6 =", PYQT_VERSION_STR)
print("Qt6   =", QLibraryInfo.version().toString())
PY

顺便做个最小运行测试

powershell 复制代码
.\.venv\Scripts\python.exe -c "from PyQt6.QtWidgets import QApplication,QLabel; app=QApplication([]); print('QApplication OK');"

运行你的程序

powershell 复制代码
.\.venv\Scripts\python.exe .\main.py

如果还需要在 PyCharm 里跑,记得把解释器切到这个虚拟环境:
Settings → Project: random_pro → Python Interpreter → 选择 .venv\Scripts\python.exe

相关推荐
二川bro2 小时前
量子计算入门:Python量子编程基础
python
夏天的味道٥3 小时前
@JsonIgnore对Date类型不生效
开发语言·python
tsumikistep3 小时前
【前后端】接口文档与导入
前端·后端·python·硬件架构
行走的陀螺仪3 小时前
.vscode 文件夹配置详解
前端·ide·vscode·编辑器·开发实践
小白学大数据3 小时前
Python爬虫伪装策略:如何模拟浏览器正常访问JSP站点
java·开发语言·爬虫·python
头发还在的女程序员5 小时前
三天搞定招聘系统!附完整源码
开发语言·python
温轻舟5 小时前
Python自动办公工具06-设置Word文档中表格的格式
开发语言·python·word·自动化工具·温轻舟
花酒锄作田5 小时前
[python]FastAPI-Tracking ID 的设计
python·fastapi
AI-智能5 小时前
别啃文档了!3 分钟带小白跑完 Dify 全链路:从 0 到第一个 AI 工作流
人工智能·python·自然语言处理·llm·embedding·agent·rag
d***95627 小时前
爬虫自动化(DrissionPage)
爬虫·python·自动化