from urllib.error import *
import urllib.request as ur
try:
url = 'https://www.baidu.com'
res = ur.urlopen(url)
print(res.read().decode('UTF-8'))
# exception urllib.error.ContentTooShortError(msg, content)
# 此异常会在 urlretrieve() 函数检测到已下载的数据量小于期待的数据量时被引发
except ContentTooShortError as e:
print(e)
# exception urllib.error.HTTPError
# 虽然是一个异常(URLError 的一个子类)
# HTTPError 也可以作为一个非异常的文件类返回值(与 urlopen() 返所回的对象相同)。 这适用于处理特殊 HTTP 错误例如作为认证请求的时候
except HTTPError as e:
print(e.code, e.reason, e.headers)
'''
code
一个 HTTP 状态码
这个数字的值对应于存放在http.server.BaseHTTPRequestHandler.responses代码字典中的某个值
reason
这通常是一个解释本次错误原因的字符串
headers
导致 HTTPError 的特定 HTTP 请求的 HTTP 响应头
'''
# exception urllib.error.URLError
# 处理程序在遇到问题时会引发此异常(或其派生的异常)。 它是 OSError 的一个子类
except URLError as e:
print(e.reason)
'''
reason
此错误的原因。 它可以是一个消息字符串或另一个异常实例
'''
python库的解析--urllib.request 引发的异常类(urllib.error库)
猜你喜欢
转载自blog.csdn.net/hide_in_darkness/article/details/108216916
今日推荐
周排行