Python爬蟲基礎(chǔ)2--urllib2

上一節(jié)我們講解如何抓取網(wǎng)頁和下載圖片,在下一節(jié)里面我們會(huì)講解如何抓取有限制抓取的網(wǎng)站
首先,我們依然用我們上一節(jié)課的方法去抓取一個(gè)大家都用來舉例的網(wǎng)站<blog.cndn.net>,本文主要分以下幾個(gè)部分:

1.抓取受限網(wǎng)頁
2.對(duì)代碼進(jìn)行一些優(yōu)化

1.抓取受限網(wǎng)頁

首先使用我們上一節(jié)學(xué)到的知識(shí)測試一下:

'''
@本程序用來抓取blog.csdn.net網(wǎng)頁
'''
import urllib

url = "http://blog.csdn.net/FansUnion"
html = urllib.urlopen(url)
#getcode()方法為返回Http狀態(tài)碼
print html.getcode()
html.close()
#輸出
403

此處我們的輸出為403,代表拒絕訪問;同理200表示請求成功完成;404表示網(wǎng)址未找到.
可見csdn已做了相關(guān)屏蔽,通過第一節(jié)的方法是無法獲取網(wǎng)頁,在這里我們需要啟動(dòng)一個(gè)新的庫:urllib2
但是我們也看到瀏覽器可以發(fā)那個(gè)文,是不是我們模擬瀏覽器操作,就可以獲取網(wǎng)頁信息.
老辦法,我們先來看看瀏覽器是如何提交請求給csdn服務(wù)器的.首先簡述一下方法:

打開網(wǎng)頁,右鍵點(diǎn)擊,選擇"inspect Element"(最下面這一項(xiàng))
點(diǎn)擊下面彈起來的框框的Network選項(xiàng)卡
刷新網(wǎng)頁,就可以看到Network選項(xiàng)卡抓取了很多信息
找到其中一個(gè)信息展開,就能看到請求包的Header

header信息查看
header信息查看

以下就是整理后的Header信息

Request Method:GET
Host:blog.csdn.net
Referer:http://blog.csdn.net/?ref=toolbar_logo
User-Agent:Mozilla/5.0 (Macintosh; Intel Mac OS X 10_10_1) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/38.0.2125.104 Safari/537.36

然后根據(jù)提取的Header信息,利用urllib2的Request方法模擬瀏覽器向服務(wù)器提交請求,代碼如下:

# coding=utf-8
'''
@本程序用來抓取受限網(wǎng)頁(blog.csdn.net)
@User-Agent:客戶端瀏覽器版本
@Host:服務(wù)器地址
@Referer:跳轉(zhuǎn)地址
@GET:請求方法為GET
'''
import urllib2

url = "http://blog.csdn.net/FansUnion"

#定制自定義Header,模擬瀏覽器向服務(wù)器提交請求
req = urllib2.Request(url)
req.add_header('User-Agent', 'Mozilla/5.0 (Windows NT 6.3; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/39.0.2171.95 Safari/537.36')
req.add_header('Host', 'blog.csdn.net')
req.add_header('Referer', 'http://blog.csdn.net')
req.add_header('GET', url)

#下載網(wǎng)頁html并打印
html = urllib2.urlopen(req)
content = html.read()
print content
html.close()

呵呵,你限制我,我就跳過你的限制.據(jù)說只要瀏覽器能夠訪問的,就能夠通過爬蟲抓取.

2.對(duì)代碼進(jìn)行一些優(yōu)化

簡化提交Header方法

發(fā)現(xiàn)每次寫那么多req.add_header對(duì)自己來說是一種折磨,有沒有什么方法可以只要復(fù)制過來就使用.答案是肯定的.

#input:
help(urllib2.Request)
#output(因篇幅關(guān)系,只取__init__方法)
__init__(self, url, data=None, headers={}, origin_req_host=None, unverifiable=False)

通過觀察,我們發(fā)現(xiàn)headers={},就是說可以以字典的方式提交header信息.那就動(dòng)手試試咯!!

#只取自定義Header部分代碼
csdn_headers = {
    "User-Agent": "Mozilla/5.0 (Windows NT 6.3; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/39.0.2171.95 Safari/537.36",
    "Host": "blog.csdn.net",
    'Referer': 'http://blog.csdn.net',
    "GET": url
    }
req = urllib2.Request(url,headers=csdn_headers)

發(fā)現(xiàn)是不是很簡單,在這里感謝斯巴達(dá)的無私賜教.

提供動(dòng)態(tài)頭部信息

如果按照上述方法進(jìn)行抓取,很多時(shí)候會(huì)因?yàn)樘峤恍畔⑦^于單一,被服務(wù)器認(rèn)為是機(jī)器爬蟲進(jìn)行拒絕.
那我們是不是有一些更為智能的方法提交一些動(dòng)態(tài)的數(shù)據(jù),答案肯定也是肯定的.而且很簡單,直接上代碼!

'''
@本程序是用來動(dòng)態(tài)提交Header信息
@random 動(dòng)態(tài)庫,詳情請參考<https://docs.python.org/2/library/random.html>
'''

# coding=utf-8
import urllib2
import random

url = 'http://www.lifevc.com/'

my_headers = [
    'Mozilla/4.0 (compatible; MSIE 8.0; Windows NT 5.1; Trident/4.0; .NET CLR 2.0.50727; .NET CLR 3.0.04506.30; .NET CLR 3.0.04506.648)',
    'Mozilla/4.0 (compatible; MSIE 8.0; Windows NT 5.1; Trident/4.0; .NET CLR 2.0.50727; InfoPath.1',
    'Mozilla/4.0 (compatible; GoogleToolbar 5.0.2124.2070; Windows 6.0; MSIE 8.0.6001.18241)',
    'Mozilla/5.0 (compatible; MSIE 9.0; Windows NT 6.1; WOW64; Trident/5.0)',
    'Mozilla/5.0 (compatible; MSIE 9.0; Windows NT 6.1; WOW64; Trident/5.0; Sleipnir/2.9.8)',
    #因篇幅關(guān)系,此處省略N條
]

random_header = random.choice(headers)
# 可以通過print random_header查看提交的header信息
req = urllib2.Request(url)
req.add_header("User-Agent", random_header)
req.add_header('Host', 'blog.csdn.net')
req.add_header('Referer', 'http://blog.csdn.net')
req.add_header('GET', url)
content = urllib2.urlopen(req).read()
print content

其實(shí)很簡單,這樣我們就完成了對(duì)代碼的一些優(yōu)化.
這一節(jié)我們主要講了如圖抓取受限制網(wǎng)站,下一節(jié)將會(huì)介紹爬蟲神兵利器BeautifulSoup.

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末兼蜈,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子丑罪,更是在濱河造成了極大的恐慌会宪,老刑警劉巖撬陵,帶你破解...
    沈念sama閱讀 217,657評(píng)論 6 505
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件囚痴,死亡現(xiàn)場離奇詭異昵济,居然都是意外死亡铲觉,警方通過查閱死者的電腦和手機(jī)逼蒙,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,889評(píng)論 3 394
  • 文/潘曉璐 我一進(jìn)店門从绘,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人是牢,你說我怎么就攤上這事僵井。” “怎么了驳棱?”我有些...
    開封第一講書人閱讀 164,057評(píng)論 0 354
  • 文/不壞的土叔 我叫張陵批什,是天一觀的道長。 經(jīng)常有香客問我社搅,道長驻债,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,509評(píng)論 1 293
  • 正文 為了忘掉前任形葬,我火速辦了婚禮合呐,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘笙以。我一直安慰自己淌实,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,562評(píng)論 6 392
  • 文/花漫 我一把揭開白布猖腕。 她就那樣靜靜地躺著拆祈,像睡著了一般。 火紅的嫁衣襯著肌膚如雪倘感。 梳的紋絲不亂的頭發(fā)上放坏,一...
    開封第一講書人閱讀 51,443評(píng)論 1 302
  • 那天,我揣著相機(jī)與錄音老玛,去河邊找鬼淤年。 笑死犁珠,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的互亮。 我是一名探鬼主播,決...
    沈念sama閱讀 40,251評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼余素,長吁一口氣:“原來是場噩夢啊……” “哼豹休!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起桨吊,我...
    開封第一講書人閱讀 39,129評(píng)論 0 276
  • 序言:老撾萬榮一對(duì)情侶失蹤威根,失蹤者是張志新(化名)和其女友劉穎,沒想到半個(gè)月后视乐,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體洛搀,經(jīng)...
    沈念sama閱讀 45,561評(píng)論 1 314
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,779評(píng)論 3 335
  • 正文 我和宋清朗相戀三年佑淀,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了留美。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 39,902評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡伸刃,死狀恐怖谎砾,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情捧颅,我是刑警寧澤景图,帶...
    沈念sama閱讀 35,621評(píng)論 5 345
  • 正文 年R本政府宣布,位于F島的核電站碉哑,受9級(jí)特大地震影響挚币,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜扣典,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,220評(píng)論 3 328
  • 文/蒙蒙 一妆毕、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧激捏,春花似錦设塔、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,838評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至图柏,卻和暖如春序六,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背蚤吹。 一陣腳步聲響...
    開封第一講書人閱讀 32,971評(píng)論 1 269
  • 我被黑心中介騙來泰國打工例诀, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留随抠,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 48,025評(píng)論 2 370
  • 正文 我出身青樓繁涂,卻偏偏與公主長得像拱她,于是被迫代替她去往敵國和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子扔罪,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,843評(píng)論 2 354

推薦閱讀更多精彩內(nèi)容

  • Spring Cloud為開發(fā)人員提供了快速構(gòu)建分布式系統(tǒng)中一些常見模式的工具(例如配置管理秉沼,服務(wù)發(fā)現(xiàn),斷路器矿酵,智...
    卡卡羅2017閱讀 134,656評(píng)論 18 139
  • Android 自定義View的各種姿勢1 Activity的顯示之ViewRootImpl詳解 Activity...
    passiontim閱讀 172,116評(píng)論 25 707
  • 1 前言 作為一名合格的數(shù)據(jù)分析師唬复,其完整的技術(shù)知識(shí)體系必須貫穿數(shù)據(jù)獲取、數(shù)據(jù)存儲(chǔ)全肮、數(shù)據(jù)提取敞咧、數(shù)據(jù)分析、數(shù)據(jù)挖掘辜腺、...
    whenif閱讀 18,072評(píng)論 45 523
  • 目錄: Python網(wǎng)絡(luò)爬蟲(一)- 入門基礎(chǔ)Python網(wǎng)絡(luò)爬蟲(二)- urllib爬蟲案例Python網(wǎng)絡(luò)爬...
    一只寫程序的猿閱讀 37,246評(píng)論 3 49
  • 本人休建,女,Android開發(fā)工程師评疗,北漂進(jìn)行時(shí)丰包,兼職微商,雖然是兼職但已經(jīng)成為自己喜歡的事業(yè)壤巷。還記得上大學(xué)那...
    兜園夢閱讀 320評(píng)論 0 0