网络爬虫处理异常的种类

每个程序都不可避免地要进行异常处理,爬虫也不例外,假如不进行异常处理,可能导致爬虫程序直接崩掉。以下是网络爬虫出现的异常种类。

URLError

通常,URLError在没有网络连接(没有路由到特定服务器),或者服务器不存在的情况下产生。

HTTPError

首先我们要明白服务器上每一个HTTP 应答对象response都包含一个数字“状态码”,该状态码表示HTTP协议所返回的响应的状态,这就是HTTPError。比如当产生“404 Not Found”的时候,便表示“没有找到对应页面”,可能是输错了URL地址,也可能IP被该网站屏蔽了,这时便要使用代理IP进行爬取数据。

两者关系

两者是父类与子类的关系,即 HTTPError URLError 的子类, HTTPError 有异常状态码与异常原因, URLError 没有异常状态码。所以,我们在处理的时候,不能使用 URLError 直接代替 HTTPError 。同时, Python 中所有异常都是基类 Exception 的成员,所有异常都从此基类继承,而且都在 exceptions 模块中定义。如果要代替,必须要判断是否有状态码属性。

猜你喜欢

转载自blog.csdn.net/lmseo5hy/article/details/80256417