python(二)urllib2.URLError-创新互联
1.URLError
从网站建设到定制行业解决方案,为提供成都网站设计、网站制作服务体系,各种行业企业客户提供网站建设解决方案,助力业务快速发展。创新互联公司将不断加快创新步伐,提供优质的建站服务。import urllib2
if name == ' main' :
url = 'http://www.567.com'
req = urllib2.Request(url)
try:
response = urllib2.urlopen(req)
#print response
html = response.read().decode('utf-8')
print html
except urllib2.URLError as e :
print e.reason
结果 :
URLError
[Errno 11004] getaddrinfo failed
2.HTTPError
import urllib2
if name == 'main' :
url = 'http://money.163.com/stocks/'
req = urllib2.Request(url)
try:
response = urllib2.urlopen(req)
#html = response.read()
except urllib2.HTTPError as e:
print e.code
结果:404
3,URLError和HTTPError混合使用
如果想用HTTPError和URLError一起捕获异常,那么需要将HTTPError放在URLError的前面,因为HTTPError是URLError的一个子类。如果URLError放在前面,出现HTTP异常会先响应URLError,这样HTTPError就捕获不到错误信息了。
一种方法:
import urllib2
if name == 'main' :
url = 'http://news.baidu.net'
req = urllib2.Request(url)
try :
response = urllib2.urlopen(req)
html = response.read().decode('utf-8')
print html
except urllib2.HTTPError as e:
print 'HTTPError'
print e.code
except urllib2.URLError as e:
print 'URLError'
print e.reason
二种方法使用函数hasattr():
if __name__ == '__main__' :
url = 'http://www.567.com'
req = urllib2.Request(url)
try:
response = urllib2.urlopen(req)
html = response.read().decode('utf-8')
print html
except urllib2.URLError as e :
if hasattr(e,'code') :
print 'HTTPError'
print e.code
elif hasattr(e,'reason') :
print 'URLError'
print e.reason
另外有需要云服务器可以了解下创新互联scvps.cn,海内外云服务器15元起步,三天无理由+7*72小时售后在线,公司持有idc许可证,提供“云服务器、裸金属服务器、高防服务器、香港服务器、美国服务器、虚拟主机、免备案服务器”等云主机租用服务以及企业上云的综合解决方案,具有“安全稳定、简单易用、服务可用性高、性价比高”等特点与优势,专为企业上云打造定制,能够满足用户丰富、多元化的应用场景需求。
当前标题:python(二)urllib2.URLError-创新互联
分享URL:http://cdiso.cn/article/dpchpd.html