编程爱好者联盟 2016-11-29
最近使用到Sphinx编译文档,出现如下异常:
Extension error:Could not import extension sphinx.builders.linkcheck (exception: cannot import name SSLError)
一开始有点摸不着头脑,明明是不能导入“sphinx.builders.linkcheck”,错误信息却是“cannot import name SSLError”
于是使用“-P”参数在异常时打开pdb调试,pdb打印信息如下:
Exception occurred while building, starting debugger:Traceback (most recent call last): File "/usr/local/lib/python2.7/dist-packages/Sphinx-1.5b1-py2.7.egg/sphinx/cmdline.py", line 295, in main opts.warningiserror, opts.tags, opts.verbosity, opts.jobs) File "/usr/local/lib/python2.7/dist-packages/Sphinx-1.5b1-py2.7.egg/sphinx/application.py", line 189, in __init__ self.setup_extension(extension) File "/usr/local/lib/python2.7/dist-packages/Sphinx-1.5b1-py2.7.egg/sphinx/application.py", line 514, in setup_extension err)ExtensionError: Could not import extension sphinx.builders.linkcheck (exception: cannot import name SSLError)
可以看到出错的地方在“application.py”,于是打开该文件一探究竟,源码如下:
进一步在pdb打印“extension”和“err”
现在可以知道,是在import的时候遇到了importerror,但是不知道具体是哪里错了,干脆另起python命令行,直接import这个扩展“sphinx.builders.linkcheck”,结果出现如下错误:
可以看到错误原因是不能从“requests.packages.urllib3.exceptions”导入“SSLError”,经验证发现,可以在“requests.exceptions”里面导入“SSLError”
而网上搜索,大多也只是提到从“requests.exceptions”导入“SSLError”。由于Sphinx是刚下载的最新版,我怀疑可能是版本不兼容的问题。
查看requests版本发现requests确实不是最新版本(官网目前最新版本为:v2.12.1):
进一步上官网确认,发现官网上有关SSLError的代码确实已经发生变化:
到此,完全确认是requests版本更新过程中改变了“SSLError”的位置(导入方式),升级requests到最新版后问题解决。