原做者及原文连接: blog.csdn.net/c406495762/…html
运行平台:Windows Python版本:Python3.x IDE:Sublime text3python
urllib.error能够接收有urllib.request产生的异常。urllib.error有两个方法,URLError和HTTPError。以下图所示:bash
URLError是OSError的一个子类,HTTPError是URLError的一个子类,服务器上HTTP的响应会返回一个状态码,根据这个HTTP状态码,咱们能够知道咱们的访问是否成功。例如第二个笔记中提到的200状态码,表示请求成功,再好比常见的404错误等。服务器
让咱们先看下URLError的异常,建立文件urllib_test06.py,编写以下代码:函数
# -*- coding: UTF-8 -*-
from urllib import request
from urllib import error
if __name__ == "__main__":
#一个不存在的链接
url = "http://www.iloveyou.com/"
req = request.Request(url)
try:
response = request.urlopen(req)
html = response.read().decode('utf-8')
print(html)
except error.URLError as e:
print(e.reason)
复制代码
咱们能够看到以下运行结果:学习
再看下HTTPError异常,建立文件urllib_test07.py,编写以下代码:ui
# -*- coding: UTF-8 -*-
from urllib import request
from urllib import error
if __name__ == "__main__":
#一个不存在的链接
url = "http://www.douyu.com/Jack_Cui.html"
req = request.Request(url)
try:
responese = request.urlopen(req)
# html = responese.read()
except error.HTTPError as e:
print(e.code)
复制代码
运行以后,咱们能够看到404,这说明请求的资源没有在服务器上找到,www.douyu.com这个服务器是存在的,可是咱们要查找的Jack_Cui.html资源是没有的,因此抛出404异常。url
最后值得注意的一点是,若是想用HTTPError和URLError一块儿捕获异常,那么须要将HTTPError放在URLError的前面,由于HTTPError是URLError的一个子类。若是URLError放在前面,出现HTTP异常会先响应URLError,这样HTTPError就捕获不到错误信息了。spa
若是不用上面的方法,也可使用hasattr函数判断URLError含有的属性,若是含有reason属性代表是URLError,若是含有code属性代表是HTTPError。建立文件urllib_test08.py,编写代码以下:.net
# -*- coding: UTF-8 -*-
from urllib import request
from urllib import error
if __name__ == "__main__":
#一个不存在的链接
url = "http://www.douyu.com/Jack_Cui.html"
req = request.Request(url)
try:
responese = request.urlopen(req)
except error.URLError as e:
if hasattr(e, 'code')
print("HTTPError")
print(e.code)
elif hasattr(e, 'reason')
print("URLError")
print(e.reason)
复制代码
运行结果以下:
圆方圆学院聚集 Python + AI 名师,打造精品的 Python + AI 技术课程。 在各大平台都长期有优质免费公开课,欢迎报名收看。 公开课地址: ke.qq.com/course/3627…
加入python学习讨论群 78486745 ,获取资料,和广大群友一块儿学习。