有的bug,莫名其妙就好了…
python3.9
报错 “AttributeError: 'HTMLParser' object has no attribute 'unescape'
” 异常分析解决。
一、问题描述
安装 python3.9
版本后,pycharm
中切换 python3.9
版本,创建虚拟环境报错:"AttributeError: 'HTMLParser' object has no attribute 'unescape'
"。
Executed command:
C:\Users\\AppData\Local\Temp\tmp41_yhcxspycharm-management\setuptools-40.8.0\setup.py installError occurred:
AttributeError: 'HTMLParser' object has no attribute 'unescape'Command output:
Traceback (most recent call last):
File "C:\Users\\AppData\Local\Temp\tmp0mv4mj35pycharm-management\setuptools-40.8.0\setup.py", line 11, in <module>
import setuptools
File "C:\Users\\AppData\Local\Temp\tmp0mv4mj35pycharm-management\setuptools-40.8.0\setuptools\__init__.py", line 20, in <module>
from setuptools.dist import Distribution, Feature
File "C:\Users\\AppData\Local\Temp\tmp0mv4mj35pycharm-management\setuptools-40.8.0\setuptools\dist.py", line 35, in <module>
from setuptools.depends import Require
File "C:\Users\\AppData\Local\Temp\tmp0mv4mj35pycharm-management\setuptools-40.8.0\setuptools\depends.py", line 7, in <module>
from .py33compat import Bytecode
File "C:\Users\\AppData\Local\Temp\tmp0mv4mj35pycharm-management\setuptools-40.8.0\setuptools\py33compat.py", line 55, in <module>
unescape = getattr(html, 'unescape', html_parser.HTMLParser().unescape)
AttributeError: 'HTMLParser' object has no attribute 'unescape'
查看官网 python3.9
的 changelog
,发现 HTMLParser.unescape
属性被移除了,并且从 python3.4
开始就被弃用。
pycharm
创建虚拟环境时,会使用到 setuptools
。而 setuptools
中,刚好使用了这个属性,所以,导致了"AttributeError: 'HTMLParser' object has no attribute 'unescape'
"异常。
经过各种分析、尝试,问题最终得到解决。记录下过程,避免更多人踩坑。
二、解决方法
先给出解决方法,感兴趣的朋友,可以继续阅读后面的分析部分。
解决这个问题,分两种情况:
1. 不通过 pycharm 编辑器,直接使用 python 解释器。
2. 在 pycharm 编辑器中使用 python 解释器。
我是在
pycharm
中使用python3.9
触发报错,所以这里也单独提出来讨论讨论。
2.1、直接使用 python 解释器
不通过 pycharm
编辑器,直接使用 python
解释器。比如,在 windows
的 cmd
,或 linux
下的命令行中使用 python
。
解决方法:更新 setuptools
版本。
我以 python3.9
使用 setuptools
为例,测试如下。
2.1.1、setuptools
低版本触发报错
以 setuptools-40.8.0
为例,测试触发报错如下:
第一步,使用 python3.9
下的 pip
卸载之前安装的 setuptools
:
E:\soft\python\python39\install>pip uninstall setuptools
第二步,安装 setuptools-40.8.0
:
E:\soft\python\python39\install>pip install setuptools==40.8.0 Collecting setuptools==40.8.0 Using cached setuptools-40.8.0-py2.py3-none-any.whl (575 kB) Installing collected packages: setuptools Successfully installed setuptools-40.8.0
第三步,在 python3.9
中导入包触发报错:
E:\soft\python\python39\install>python
Python 3.9.0 (tags/v3.9.0:9cf6752, Oct 5 2020, 15:34:40) [MSC v.1927 64 bit (AMD64)] on win32
Type "help", "copyright", "credits" or "license" for more information.
> import setuptools
Traceback (most recent call last):
File "<stdin>", line 1, in <module>
File "E:\soft\python\python39\install\lib\site-packages\setuptools\__init__.py", line 20, in <module>
from setuptools.dist import Distribution, Feature
File "E:\soft\python\python39\install\lib\site-packages\setuptools\dist.py", line 35, in <module>
from setuptools.depends import Require
File "E:\soft\python\python39\install\lib\site-packages\setuptools\depends.py", line 7, in <module>
from .py33compat import Bytecode
File "E:\soft\python\python39\install\lib\site-packages\setuptools\py33compat.py", line 55, in <module>
unescape = getattr(html, 'unescape', html_parser.HTMLParser().unescape)
AttributeError: 'HTMLParser' object has no attribute 'unescape'
2.1.2、setuptools
高版本解决报错
以 setuptools-49.2.1
为例,测试如下:
第一步,卸载之前安装的 setuptools
:
E:\soft\python\python39\install>pip uninstall setuptools Found existing installation: setuptools 40.8.0 Uninstalling setuptools-40.8.0: Would remove: e:\soft\python\python39\install\lib\site-packages\easy_install.py e:\soft\python\python39\install\lib\site-packages\pkg_resources\* e:\soft\python\python39\install\lib\site-packages\setuptools-40.8.0.dist-info\* e:\soft\python\python39\install\lib\site-packages\setuptools\* e:\soft\python\python39\install\scripts\easy_install-3.9.exe e:\soft\python\python39\install\scripts\easy_install.exe Proceed (y/n)"htmlcode">E:\soft\python\python39\install>pip install setuptools==49.2.1 Collecting setuptools==49.2.1 Using cached setuptools-49.2.1-py3-none-any.whl (789 kB) Installing collected packages: setuptools Successfully installed setuptools-49.2.1第三步,在
python3.9
中导入包:E:\soft\python\python39\install>python Python 3.9.0 (tags/v3.9.0:9cf6752, Oct 5 2020, 15:34:40) [MSC v.1927 64 bit (AMD64)] on win32 Type "help", "copyright", "credits" or "license" for more information. > import setuptools > setuptools.__version__ '49.2.1' >目前最新版本,应该是到
setuptools-50.3.2
了 。2.2、在 pycharm 中使用 python 解释器
在
pycharm
中创建python3.9
虚拟环境报错,本质上也是使用了setuptools
的低版本导致。
我尝试过更新setuptools
为更高的版本,但pycharm
还是顽固的使用了setuptools-40.8.0
,如最开始的报错信息所示…我不知道是
pycharm
中的某些默认配置导致,还是pycharm
的版本属性导致它使用了低版本的setuptools
,如果有朋友知道,欢迎告知。虽然,不知道
pycharm
中选择低版本setuptools
的原因。这里,也简单提供两种解决方法吧~2.2.1、
virtualenv
创建虚拟环境
virtualenv
为应用提供隔离的Python
运行环境,可以解决不同应用间多版本python
的冲突问题。利用
virtualenv
创建虚拟环境后,pycharm
中创建虚拟环境时,选择已存在的虚拟环境,可以避开报错。第一步: 确认
python3.9
对应的pip
工具。
如果没有配环境变量,可以直接从安装路径下打开cmd
工具。一般在python
安装目录下的Scripts
文件夹内。使用pip -V
可以查看pip
对应的python
版本。E:\soft\python\python39\install>pip -V pip 20.2.4 from e:\soft\python\python39\install\lib\site-packages\pip (python 3.9)第二步: 安装
virtualenv
。pip install virtualenv第三步: 创建虚拟环境。
virtualenv
指令用于创建虚拟环境,后跟虚拟环境保存路径。virtualenv E:\soft\python\python39\env如果需要删除虚拟环境,直接删除对应文件夹即可。
第四步:
pycharm
中选择已存在的虚拟环境。
"File
-->Settings
-->Python Interpreter
",进入对应界面。这里,需要选择到虚拟环境中的
python.exe
,否则OK
键为灰色,无法点击。通过该方法,可以在原本报错的
pycharm
中创建python3.9
虚拟环境。2.2.2、
pycharm
版本更换报错版本为:
pycharm-community-2019.2.1
。
下载安装最新版本:pycharm-community-2020.2.3
。点击运行要安装的
pycharm-community-2020.2.3.exe
文件,会自动检测,提示卸载已安装的pycharm
。为避免其他问题,卸载过程中,可以选择删除旧版本配置等。
经过测试,使用最新版本
pycharm
可以成功创建python3.9
虚拟环境。
为了验证是否为pycharm
的版本兼容问题,我卸载最新版本,重新安装旧版本pycharm
后,依然报错!我猜测是固定的pycharm
版本,使用了固定的某些setuptools
版本,导致了兼容性报错。我也怀疑过是系统中多个版本
python
的环境变量顺序,导致pycharm
找到了错误的依赖项。尝试在环境变量中将python3.9
相关值移动到最前面,依然不能解决问题。看来,最新的
python
还是得配最新的pycharm
!编码界的爱情故事么…三、原因分析
感兴趣的朋友,欢迎继续阅读。
从
Traceback
报错日志中,可以看到,是在setuptools-40.8.0\setuptools\py33compat.py
的55行, 执行unescape = getattr(html, 'unescape', html_parser.HTMLParser().unescape)
时,抛出了AttributeError: 'HTMLParser' object has no attribute 'unescape'
异常。可以肯定是由
setuptools
引起的报错。这里有一个关键的信息:py33compat.py
文件。
pyXXcompat.py
是setuptools
兼容python
版本相关的文件。进入到
..\Lib\site-packages\setuptools
查看setuptools-40.8.0
的安装文件,可以看到,包含了py27compat.py
、py31compat.py
、py33compat.py
。进入到
..\Lib\site-packages\setuptools
查看setuptools-49.2.1
的安装文件,可以看到,只包含了py34compat.py
。而我们从
python3.9
的changelog
中,可以知道HTMLParser.unescape
属性被移除了,并且从python3.4
开始就被弃用了。所以,从兼容
python3.4
开始,setuptools
中就放弃了使用HTMLParser.unescape
。
因此,只要包含py34compat.py
文件的setuptools
版本,就能兼容python3.9
版本。
稳了!魔兽国服回归的3条重磅消息!官宣时间再确认!
昨天有一位朋友在大神群里分享,自己亚服账号被封号之后居然弹出了国服的封号信息对话框。
这里面让他访问的是一个国服的战网网址,com.cn和后面的zh都非常明白地表明这就是国服战网。
而他在复制这个网址并且进行登录之后,确实是网易的网址,也就是我们熟悉的停服之后国服发布的暴雪游戏产品运营到期开放退款的说明。这是一件比较奇怪的事情,因为以前都没有出现这样的情况,现在突然提示跳转到国服战网的网址,是不是说明了简体中文客户端已经开始进行更新了呢?
更新日志
- 好薇2024《兵哥哥》1:124K黄金母盘[WAV+CUE]
- 胡歌.2006-珍惜(EP)【步升大风】【FLAC分轨】
- 洪荣宏.2014-拼乎自己看【华特】【WAV+CUE】
- 伊能静.1999-从脆弱到勇敢1987-1996精选2CD【华纳】【WAV+CUE】
- 刘亮鹭《汽车DJ玩主》[WAV+CUE][1.1G]
- 张杰《最接近天堂的地方》天娱传媒[WAV+CUE][1.1G]
- 群星《2022年度发烧天碟》无损黑胶碟 2CD[WAV+CUE][1.4G]
- 罗文1983-罗文甄妮-射雕英雄传(纯银AMCD)[WAV+CUE]
- 群星《亚洲故事香港纯弦》雨果UPMAGCD2024[低速原抓WAV+CUE]
- 群星《经典咏流传》限量1:1母盘直刻[低速原抓WAV+CUE]
- 庾澄庆1993《老实情歌》福茂唱片[WAV+CUE][1G]
- 许巍《在别处》美卡首版[WAV+CUE][1G]
- 林子祥《单手拍掌》华纳香港版[WAV+CUE][1G]
- 郑秀文.1997-我们的主题曲【华纳】【WAV+CUE】
- 群星.2001-生命因爱动听电影原创音乐AVCD【MEDIA】【WAV+CUE】