python中的异常(结合爬虫)
python中有一个非常重要的功能来处理程序中出现异常和错误
一个是断言,还有一个就是异常处理
现在我们来看下异常处理;
python标准异常(记住常用的就可以)
异常的概念
异常即是一个事件,该事件会在程序执行过程中发生,影响了程序的正常执行。
一般情况下,在Python无法正常处理程序时就会发生一个异常。
异常是Python对象,表示一个错误。当Python脚本发生异常时我们需要捕获处理它,否则程序会终止执行。
异常处理
捕捉异常可以使用try/except语句:try/except语句用来检测try语句块中的错误,从而让except语句捕获异常信息并处理。
如果你不想在异常发生时结束你的程序,只需在try里捕获它。
以下为简单的try....except...else的语法:
try:
<语句> #运行别的代码
except <名字>:
<语句> #如果在try部份引发了'name'异常
except <名字>,<数据>:
<语句> #如果引发了'name'异常,获得附加的数据
else:
<语句> #如果没有异常发生
try的工作原理是,当开始一个try语句后,python就在当前程序的上下文中作标记,这样当异常出现时就可以回到这里,try子句先执行,接下来会发生什么依赖于执行时是否出现异常。
如果当try后的语句执行时发生异常,python就跳回到try并执行第一个匹配该异常的except子句,异常处理完毕,控制流就通过整个try语句(除非在处理异常时又引发新的异常)。
如果在try后的语句里发生了异常,却没有匹配的except子句,异常将被递交到上层的try,或者到程序的最上层(这样将结束程序,并打印缺省的出错信息)。
如果在try子句执行时没有发生异常,python将执行else语句后的语句(如果有else的话),然后控制流通过整个try语句。
try:
正常的操作
......................except:
发生异常,执行这块代码
......................else:
如果没有异常执行这块代码
现在看一下我们的异常
import requests
from requests.exceptions import HTTPError,ConnectionError
url_list=[
'http://www.langlang2017.com',
'http://www.xxx.com/0000000000000000000000',
'https://www.baidu.com'
]
for url in url_list:
try:
response=requests.get(url)
print('---------------')
print(url)
except ConnectionError:
with open('有问题的网站.txt','a',encoding='utf8') as fp:
fp.write(url+'\n')
except Exception as e:
print(e)
显示结果: