urllib:处理网络异常

Posted gxj521test

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了urllib:处理网络异常相关的知识,希望对你有一定的参考价值。

from urllib import request, error
import ssl
import urllib.request
import socket
import urllib.error
ssl._create_default_https_context = ssl._create_unverified_context

1.URLError

try:
    response = request.urlopen(‘http://gxj.com‘)
except error.URLError as e:
    print(e.reason)

2.HTTPError

try:
    response =request.urlopen(‘https://cuiqingcai.com/index.htm‘)
except error.HTTPError as  e:
    print(e.code, e.headers, e.reason)

3.最好的写法先捕获子类的错误在捕获父类

try:
    response = request.urlopen(‘https://cuiqingcai.com/index.htm‘)
except error.HTTPError as e:
    print(e.reason, e.code, e.headers)
except error.URLError as e:
    print(e.reason)
else:
    print(‘Request Successfully‘)
#4.error 里reason属性返回的不一定是字符串,也可能是一个对象
try:
    response = urllib.request.urlopen(‘https://cuiqingcai.com‘, timeout=1)
except socket.timeout as e:
    print(type(e))

以上是关于urllib:处理网络异常的主要内容,如果未能解决你的问题,请参考以下文章

urllib2的异常处理

Python3 爬虫03_urllib.error异常处理

5URLerror异常处理

python爬虫怎么处理豆瓣网页异常请求

芝麻HTTP:Python爬虫入门之URLError异常处理

Python3网络爬虫:urllib.error异常