python爬虫(四)_urllib2库的基本使用

本篇我们将开始学习如何进行网页抓取,更多内容请参考:python学习指南

urllib2库的基本使用

所谓网页抓取,就是把URL地址中指定的网络资源从网络流中读取出来,保存到本地。在Python中有很多库可以用来抓取网页,我们先学习urllib2

urllib2是Python2.x自带的模块(不需要下载,导入即可使用)
urllib2官网文档:https://docs.python.org/2/library/urllib2.html
urllib2源码

urllib2在python3.x中被改为urllib.request

urlopen

我们先来段代码:

#-*- coding:utf-8 -*-
#01.urllib2_urlopen.py#导入urllib2库import urllib2 #向指定的url发送请求,并返回服务器的类文件对象 response = urllib2.urlopen("http://www.baidu.com") #类文件对象支持文件对象的操作方法,如read()方法读取文件 html = response.read() #打印字符串 print(html)

执行写好的python代码,将打印结果:

python2 01.urllib2_urlopen.py 

实际上,如果我们在浏览器打上百度主页,右键选择"查看源代码",你会发现,跟我们刚才打印出来的是一模一样的。也就是说,上面的4行代码就已经帮我们把百度的首页的全部代码爬了下来。
一个基本的url请求对应的python代码真的非常简单。

Request

查看官方文档url的用法如下:

urllib2.urlopen(url[, data[, timeout[, cafile[, capath[, cadefault[, context]]]]])Open the URL url, which can be either a string or a Request object.

在我们第一个例子里,urlopen()的参数就是一个url地址;
但是如果需要执行更复杂的操作,比如增加http报头,则必须创建一个Request实例来作为urlopen()的参数;而需要访问的url地址则作为Request实例的参数。

#-*- coding:utf-8 -*-
#02.urllib2_request.pyimport urllib2#url作为Request()方法的参数,构造并返回一个Request对象 request = urllib2.Request("http://www.baidu.com") #Request对象作为一个urlopen()方法的参数,发送给服务器并接收响应 response = urllib2.urlopen(request) html = response.read() print(html)

运行结果是完全一样的:

新建Request实例,除了必须要有url参数之外,还可以设置另外两个参数:

  1. data(默认空):是伴随url提交的数据(比如要post的数据),同时HTTP请求将从"GET"方式改为"POST"方式。
  2. headers(默认空):是一个字典,包含了需要发送的HTTP报头的键值对。
    这两个参数下面会说到。

User-Agent

但是这样直接用urllib2给一个网站发送请求的话,确实略有些唐突了,就好比,人家每家都有门,你以一个路人的身份直接闯进去显然不是很礼貌。而且有一些站点不喜欢被程序(非人为访问)访问,有可能会拒绝你的访问请求。

但是如果我们用一个合法的身份去请求别人网站,显然人家就是欢迎的,所以我们就应该给我们的这个代码加上一个身份,就是所谓的User-Agent头。

  • 浏览器就是互联网世界公认被允许的身份,如果我们希望我们的爬虫程序更像一个真实用户,那我们第一步,就是需要伪装成一个被公认的浏览器。用不同的浏览器在发送请求的时候,会有不同的User-Agent头。urllib2默认的User-Agent头为:Python-urllib/x.y(x和y是Python主版本和次版本号,例如Python-urllib/2.7)
#-*- coding:utf-8 -*-
#03.urllib2_useragent.pyimport urllib2url = "http://www.itcast.cn" #IE 9.0的User-Agent,包含ua-header里 ua_header = {"User-Agent":"Mozilla/5.0 (compatible; MSIE 9.0; Windows NT 6.1; Trident/5.0;"} # url连同headers,一起构造Request请求,这个请求将附带IE9.0浏览器的User-Agent request = urllib2.Request(url, headers = ua_header) #向服务器发送这个请求 response = urllib2.urlopen(request) html = response.read() print(html)

添加更多的Header信息

在HTTP Request中加入特定的Header,来构造一个完整的HTTP请求。

可以通过调用Request.add_header()添加/修改一个特定的header也可以通过调用Request.get_header()来查看已有的header。

  • 添加一个特定的header
#-*- coding:utf-8 -*-
#04.urllib2_headers.pyimport urllib2url = "http://www.itcast.cn" #IE 9.0的User-Agent header = {"User-Agent":"Mozilla/5.0 (compatible; MSIE 9.0; Windows NT 6.1; Trident/5.0;"} request =urllib2.Request(url, headers = header) #也可以通过调用Request.add_header()添加/修改一个特定的header request.add_header("Connection","keep-alive") #也可以通过调用Request.get_header()来查看header信息 request.get_header(header_name = "Connection") response = urllib2.urlopen(request) print(response.code) #可以查看响应状态码 html = response.read() print(html)
  • 随机添加/修改User-Agent
#-*- coding:utf-8 -*-
#05.urllib2_add_headers.pyimport urllib2
import random url = "http://www.itcast.cn" ua_list = [ "Mozilla/5.0 (Windows NT 6.1; ) Apple.... ", "Mozilla/5.0 (X11; CrOS i686 2268.111.0)... ", "Mozilla/5.0 (Macintosh; U; PPC Mac OS X.... ", "Mozilla/5.0 (Macintosh; Intel Mac OS... " ] user_agent = random.choice(ua_list) request = urllib2.Request(url) #也可以通过调用Request.add_header()添加/修改一个特定的header request.add_header("User-Agent", user_agent) #第一个字母大写,后面的全部小写 request.add_header("User-agent") response = urllib2.urlopen(req) html = response.read() print(html)

注意

The urllib2 module has been split across several modules in Python 3 named urllib.request and urllib.error

转载于:https://www.cnblogs.com/moying-wq/p/10134497.html

python爬虫(四)_urllib2库的基本使用相关推荐

  1. python爬虫(四)_urllib2:handle处理器和自定义opener

    opener和handleer 我们之前一直使用的是urllib2.urlopen(url)这种形式来打开网页,它是一个特殊的opener(也就是模块帮我们建好的),opener是urllib2.Op ...

  2. Python爬虫之selenium库使用详解

    Python爬虫之selenium库使用详解 本章内容如下: 什么是Selenium selenium基本使用 声明浏览器对象 访问页面 查找元素 多个元素查找 元素交互操作 交互动作 执行JavaS ...

  3. python爬虫之urllib库详解

    python爬虫之urllib库详解 前言 一.urllib库是什么? 二.urllib库的使用 urllib.request模块 urllib.parse模块 利用try-except,进行超时处理 ...

  4. Python爬虫环境常用库安装

    Python爬虫环境常用库安装 1:urllib urllib.request 这两个库是python自带的库,不需要重新安装,在python中输入如下代码: import urllib import ...

  5. Python爬虫之Scrapy库的下载和安装

    Python爬虫之Scrapy库的下载和安装 下载scrapy库 1.点击https://www.lfd.uci.edu/~gohlke/pythonlibs,进入该网页后Ctrl+F输入scrapy ...

  6. python爬虫基础-requests库

    python爬虫基础-requests库 python爬虫 1.什么是爬虫? 通过编写程序,模拟浏览器上网,然后让其去互联网上抓取数据的过程. 注意:浏览器抓取的数据对应的页面是一个完整的页面. 为什 ...

  7. [Python爬虫] 四、数据抓取之HTTP/HTTPS抓包工具Fiddler

    往期内容提要: [Python爬虫] 一.爬虫原理之HTTP和HTTPS的请求与响应 [Python爬虫] 二.爬虫原理之定义.分类.流程与编码格式 [Python爬虫] 三.数据抓取之Request ...

  8. python怎么安装requests库-Python爬虫入门requests库的安装与使用

    Requests库的详细安装过程 对于初学Python爬虫小白,认识和使用requests库是第一步,requests库包含了网页爬取 的常用方法.下面开始安装requests库. 1.检查是否安装过 ...

  9. python request库_【Python爬虫】Request库入门

    什么是爬虫? 网络爬虫(又被称为网页蜘蛛,网络机器人,在FOAF社区中间,更经常的称为网页追逐者),是一种按照一定的规则,自动地抓取万维网信息的程序或者脚本.另外一些不常使用的名字还有蚂蚁.自动索引. ...

最新文章

  1. linux C 多线程编程
  2. 关于UnimplementedError: Fused conv implementation does not support grouped convolutions for now.报错
  3. 在线作图|如何绘制一张三元相图
  4. 强化学习在携程酒店推荐排序中的应用探索
  5. django 完整日志配置
  6. telegram电脑一直显示连接中_小事不求人!学会这个方法,一个电脑连接多个显示器不再是问题...
  7. 那些值得思考的PHP问题
  8. 提高 Google 搜索效率的基本语法
  9. vue 点击div 获取位置_vue接入腾讯位置服务之点击事件
  10. 16. Django实战:云笔记项目
  11. java只对_只对你情有独钟:写给Java的情诗
  12. 深度学习:NLP之词嵌入(Word Embedding)
  13. html添加省市县联动下拉框,JSON+JS实现省市县三级联动下拉框
  14. 《python深度学习》笔记(八):回归问题
  15. AD7705和压力传感器的计算
  16. python通过经纬度在地图标点_只要两步,用Python将地址标记在地图上!
  17. 黑色温敏性PNIPAM-AuNPs/CHOL-AuNPs纳米金粒修饰聚合物的制备过程
  18. apache camel 相关配置_Apache Camel简介与入门-java
  19. HTML CSS实现 轮播图 遮罩层
  20. 微型四轴DIY机架,轻巧稳固耐摔,通用720空心杯电机,9厘米轴距

热门文章

  1. SQL Server 数据类型陷阱
  2. php实现中间件6,THINKPHP6 实现中间件
  3. 软件随想--写牛B的代码
  4. asp.net 页面右下角弹出类似QQ或MSN的消息提示
  5. Excel导出时数据中有特殊字符的可能会出错
  6. 2020-03-25 赵子清汇编语言教程
  7. 【推荐】树莓派设备+AndroidThings操作系统+TensorFlow图像识别SDK
  8. 如何鉴别项目经理/软件设计师的水平
  9. [短评]什么是大教堂与集市(和谐)
  10. 淘宝开放平台SDK对接