时间:2021-05-22
这段时间在技术上没太多的思考的,只是碰到几个虾米小问题。 往往问题不大,也会致使你花心思去排解。
今遇到一个reqeusts返回值的一个问题,花了不短时间调,后来发现是reqeusts返回的对象也含有 魔法函数 处理。
我这边的业务是cdn的刷新预缓存,对于该项目来说 http code 200, 2xx, 404 都是友好的。
为什么没有输出ok ? 按照常理来说,只要r不为 零值,就可以匹配到True. 但这次的返回是 <Response [404]>,为什么404会引起 if r 判断异常。
> type(r)
> requests.models.Response
看 requests的源代码可以很容易分析出该问题。
#jb51.netclass Response(object): """The :class:`Response <Response>` object, which contains a server's response to an HTTP request. """ __attrs__ = [ '_content', 'status_code', 'headers', 'url', 'history', 'encoding', 'reason', 'cookies', 'elapsed', 'request' ] def __init__(self): super(Response, self).__init__() self._content = False self._content_consumed = False #: Integer Code of responded HTTP Status, e.g. 404 or 200. self.status_code = None def __repr__(self): return '<Response [%s]>' % (self.status_code) def __bool__(self): return self.ok @property def ok(self): try: self.raise_for_status() except HTTPError: return False return True def raise_for_status(self): ¦ """Raises stored :class:`HTTPError`, if one occurred.""" ¦ http_error_msg = '' ¦ if 400 <= self.status_code < 500: ¦ ¦ http_error_msg = '%s Client Error: %s for url: %s' % (self.status_code, self.reason, self.url) ¦ elif 500 <= self.status_code < 600: ¦ ¦ http_error_msg = '%s Server Error: %s for url: %s' % (self.status_code, self.reason, self.url) ¦ if http_error_msg: ¦ ¦ raise HTTPError(http_error_msg, response=self)END.
以上这篇python requests response值判断方式就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
本文主要涉及python爬虫知识点:web是如何交互的requests库的get、post函数的应用response对象的相关函数,属性python文件的打开,
昨天带伙伴萌学习python爬虫,准备了几个简单的入门实例涉及主要知识点:web是如何交互的requests库的get、post函数的应用response对象的
①GET#-*-coding:utf-8-*-importrequestsdefget(url,datas=None):response=requests.ge
网址:https:///search_content/?'+urlencode(params)try:response=requests.get(url
如下所示:#requests模块来请求页面#lxml模块的html构建selector选择器(格式化响应response)#fromlxmlimporthtml