【小技巧】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

相关推荐
Lucifer__hell2 小时前
【python+tkinter】图形界面简易计算器的实现
开发语言·python·tkinter
2301_812914872 小时前
py day34 装饰器
开发语言·python
我的xiaodoujiao3 小时前
使用 Python 语言 从 0 到 1 搭建完整 Web UI自动化测试学习系列 24--数据驱动--参数化处理 Excel 文件 1
python·学习·测试工具·pytest
开心-开心急了3 小时前
关于Flutter与Qt for python 的一些技术、开源、商用等问题
开发语言·python·qt·flutter
@小码农3 小时前
2025年北京海淀区中小学生信息学竞赛第一赛段试题(附答案)
人工智能·python·算法·蓝桥杯
schinber4 小时前
使用pycharm自带debug模式运行flask时报错
ide·pycharm·flask
Q_Q19632884754 小时前
python+django/flask基于机器学习的就业岗位推荐系统
spring boot·python·django·flask·node.js·php
AI科技星5 小时前
张祥前统一场论动量公式P=m(C-V)误解解答
开发语言·数据结构·人工智能·经验分享·python·线性代数·算法
海琴烟Sunshine5 小时前
leetcode 345. 反转字符串中的元音字母 python
python·算法·leetcode