前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >Python——爬虫入门 Urllib库的进阶

Python——爬虫入门 Urllib库的进阶

作者头像
Originalee
发布2018-08-30 11:03:08
5080
发布2018-08-30 11:03:08
举报
文章被收录于专栏:编程之旅编程之旅

上一篇文章我们简单讲解了Urllib库的基础用法,包括如何获取请求之后的页面响应,如何使用POST请求上传数据,今天我们就来讲讲Urllib库的几个进阶用法。

Headers:

我们先讨论关于请求头的使用,如何构造HTTP-Headers。我们先进入Chrome浏览器打开调试模式,

在network一栏中找到Headers,在里面我们能看到Request Headers,这就是我们发送当前页面请求所用的请求头。其中User-Agent就是请求的身份,如果没有写入这个信息,那么有可能初级的反爬虫策略就会识别我们不是基于浏览器的请求,这次的请求就不会被响应了。

所以我们今天的第一段代码就是展示如何构造这个User-Agent的请求头:

代码语言:javascript
复制
import urllib  
import urllib2  
 
url = 'http://originalix.github.io/#blog'
user_agent = 'Mozilla/5.0 (Macintosh; Intel Mac OS X 10_13_1) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/64.0.3282.140 Safari/537.36'  
headers = { 'User-Agent' : user_agent }  
request = urllib2.Request(url, None, headers)  
response = urllib2.urlopen(request)
html = response.read()
print html

上面的代码中的请求,我们就构造了一个携带携带User-Agent字段的请求,以后如果没有响应的页面,可要记得检查检查是不是忘记了在请求头里做文章了。

URLError:

通常,URLError被抛出是因为网络请求出现了错误,比如服务器访问错误,或者访问的站点不存在,在这种情况下都会抛出一个URLError,这个错误是一个包含着reason和code的元组,分别对应着错误消息和错误代码。我们可以用try/except语句来捕获异常,例如:

代码语言:javascript
复制
# URLError
import urllib2

req = urllib2.Request = ('http://www.lixxxxxxxx.com')
try:
    urllib2.urlopen(req)
except urllib2.URLError as e :
    print e.reason

在接触URLError之前,大家一定更早的接触过HTTPError,每个来自服务器的HTTP应答都会携带着一个包含数值的状态码,例如我们耳熟能详的200、404(页面丢失)、403(请求被禁止)等等。HTTPError的异常实例拥有一个整型的code属性。

代码语言:javascript
复制
# 同时处理HTTPError和URLError

import urllib2

url = 'http://www.lixxxxxxxx.com'
req = urllib2.Request(url)
try:
    response = urllib2.urlopen(req)
except urllib2.HTTPError as e:
    print e.code
    print 'we can not fulfill the request \n'
except urllib2.URLError as e:
    print e.reason
    print 'we can not reach a server'
else:
    print('No problem')

上面的代码是一个同时处理HTTPError和URLError的例子,记得一定要把HTTPError放在前面处理,因为HTTPError是URLError的子集。

最后诸如代理什么的也就不讲解了,因为我觉得使用到这些的时候,大家可能就不会使用urllib2这个库了,有更好的轮子在等着你们。放上urllib2库的官方文档,有不懂的可以速查哟。 urllib2官方文档任意门

本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2018.02.07 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • Headers:
  • URLError:
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档