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

相关推荐
七夜zippoe13 小时前
领域驱动设计在Python中的实现:从理论到生产级实践
数据库·python·sqlite·ddd·pydantic
TG_imqfxt66613 小时前
虚拟机下安装苹果系统,虚拟机下如何实现协议群发iMessage?
python·objective-c
weixin_4624462313 小时前
使用 Python 创建和导出 Jupyter Notebook:从零到一的完整教程
开发语言·python·jupyter
杭州龙立智能科技13 小时前
专业的厂内运输车智能化厂家
大数据·人工智能·python
半熟的皮皮虾13 小时前
又重新写了个PDF工具箱-转换office格式/合并/拆分/删除常见操作都有了
python·程序人生·pdf·flask·开源·json·学习方法
ASD123asfadxv13 小时前
【技术实践】基于YOLO11-Seg与DySnakeConv的14种杂草智能识别系统
python
木土雨成小小测试员13 小时前
Python测试开发之前端二
javascript·python·jquery
小二·13 小时前
Python Web 开发进阶实战:Flask-Login 用户认证与权限管理 —— 构建多用户待办事项系统
前端·python·flask
两万五千个小时14 小时前
Claude Code 中的子 Agent 派生实现:Task Tool 完全指南
人工智能·python
浩瀚之水_csdn14 小时前
python字符串解析
前端·数据库·python