python函數(shù)深入淺出 14.urllib.urlopen(url).read()函數(shù)詳解

1.函數(shù)名及其來源

這是python內(nèi)置的一個(gè)網(wǎng)絡(luò)請(qǐng)求模塊泵殴,無需安裝即可使用
一般來說爬蟲更為常用的是requests庫秀又。

通常寫法如下:

import urllib

response = urllib.request.urlopen('https://www.python.org')
print(response.read())

這里簡(jiǎn)單解釋下我們請(qǐng)求一個(gè)網(wǎng)頁信息的過程。通常我們使用瀏覽器請(qǐng)求一個(gè)網(wǎng)址的信息贬芥,比如www.baidu.com

一:輸入網(wǎng)址
那肯定是輸入你要訪問的網(wǎng)站網(wǎng)址了吐辙,俗稱url,比如www.baidu.com

二:緩存解析
瀏覽器獲取了這個(gè)url蘸劈,當(dāng)然就去解析了昏苏,它先去緩存當(dāng)中看看有沒有,從 瀏覽器緩存-系統(tǒng)緩存-路由器緩存 當(dāng)中查看威沫,如果有從緩存當(dāng)中顯示頁面贤惯,然后沒有那就進(jìn)行步驟三;

三: 域名解析
在發(fā)送http之前棒掠,需要進(jìn)行DNS解析即域名解析救巷。
DNS解析:域名到IP地址的轉(zhuǎn)換過程。域名的解析工作由DNS服務(wù)器完成句柠。解析后可以獲取域名相應(yīng)的IP地址

四:tcp連接浦译,三次握手
在域名解析之后,瀏覽器向服務(wù)器發(fā)起了http請(qǐng)求溯职,tcp連接精盅,三次握手建立tcp連接。TCP協(xié)議是面向連接的谜酒,所以在傳輸數(shù)據(jù)前必須建立連接

五:服務(wù)器收到請(qǐng)求
服務(wù)器收到瀏覽器發(fā)送的請(qǐng)求信息叹俏,返回一個(gè)響應(yīng)頭response header和一個(gè)響應(yīng)體response body。

六:頁面渲染
瀏覽器收到服務(wù)器發(fā)送的響應(yīng)頭和響應(yīng)體僻族,進(jìn)行客戶端渲染粘驰,生成Dom樹、解析css樣式述么、js交互蝌数。

這里urllib就模擬了瀏覽器除了最后頁面渲染外其他步驟。

2.函數(shù)定義源碼及其用法拆解

urllib.request.urlopen(url, data=None, [timeout, ]*, cafile=None, capath=None, cadefault=False, context=None)

參數(shù)說明:

  • url:訪問的地址度秘,一般不只是地址顶伞。

  • data:此參數(shù)為可選字段,特別要注意的是剑梳,如果選擇唆貌,請(qǐng)求變?yōu)閜ost傳遞方式,其中傳遞的參數(shù)需要轉(zhuǎn)為bytes,如果是我們只需要通過urllib.parse.urlencode轉(zhuǎn)換即可:

  • timeout:設(shè)置網(wǎng)站的訪問超時(shí)時(shí)間

其他參數(shù):

  • context 參數(shù):它必須是 ssl.SSLContext 類型垢乙,用來指定 SSL 設(shè)置锨咙。

  • cafile 和 capath 兩個(gè)參數(shù):是指定CA證書和它的路徑,這個(gè)在請(qǐng)求 HTTPS 鏈接時(shí)會(huì)有用追逮。

  • cadefault 參數(shù):現(xiàn)在已經(jīng)棄用了酪刀,默認(rèn)為 False

Python3中將python2.7的urllib和urllib2兩個(gè)包合并成了一個(gè)urllib庫粱侣,其主要包括一下模塊:

  • urllib.request 請(qǐng)求模塊

  • urllib.error 異常處理模塊

  • urllib.parse url解析模塊

  • urllib.robotparser robots.txt解析模塊

urlopen返回對(duì)象提供方法:

  • read() , readline() ,readlines() , fileno() , close() :對(duì)HTTPResponse類型數(shù)據(jù)進(jìn)行操作。

  • info():返回HTTPMessage對(duì)象蓖宦,表示遠(yuǎn)程服務(wù)器返回的頭信息。

  • getcode():返回Http狀態(tài)碼油猫。

  • geturl():返回請(qǐng)求的url

爬蟲內(nèi)容較多稠茂,此處僅舉例請(qǐng)求Python官方網(wǎng)站http://python.org/

import urllib.request
response = urllib.request.urlopen('http://python.org/')
print("查看response的返回類型",type(response))
print("查看響應(yīng)的信息",response)
print("查看頭部信息1",response.info())
print("查看頭部信息2",response.getheaders())
print("查看頭部的server屬性信息",response.getheader("Server"))
print("查看響應(yīng)的狀態(tài)信息",response.status)
print("查看響應(yīng)狀態(tài)碼",response.getcode())
print("查看響應(yīng)的url地址",response.geturl())
page = response.read()
print("輸出網(wǎng)頁源碼:",page.decode('utf-8'))

3.版本差異

python2中使用urlib2請(qǐng)求

  • urllib2.urlopen可以接受一個(gè)Request對(duì)象或者url,(在接受Request對(duì)象時(shí)候情妖,并以此可以來設(shè)置一個(gè)URL
    的headers)睬关,urllib.urlopen只接收一個(gè)url
  • urllib 有urlencode,urllib2沒有
    所以python2中兩者通常一起使用。

在Python3中包urllib2歸入了urllib中毡证,所以要導(dǎo)入urllib.request电爹,并且要把urllib2替換成urllib.request

4.學(xué)習(xí)建議

實(shí)際使用中更多用到更強(qiáng)大的requests庫,這個(gè)作為基礎(chǔ)學(xué)習(xí)即可料睛。

對(duì)基礎(chǔ)運(yùn)行環(huán)境有疑問的丐箩,推薦參考:python函數(shù)深入淺出 0.基礎(chǔ)篇

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市恤煞,隨后出現(xiàn)的幾起案子屎勘,更是在濱河造成了極大的恐慌,老刑警劉巖居扒,帶你破解...
    沈念sama閱讀 216,591評(píng)論 6 501
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件概漱,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡喜喂,警方通過查閱死者的電腦和手機(jī)瓤摧,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,448評(píng)論 3 392
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來玉吁,“玉大人照弥,你說我怎么就攤上這事〗保” “怎么了产喉?”我有些...
    開封第一講書人閱讀 162,823評(píng)論 0 353
  • 文/不壞的土叔 我叫張陵,是天一觀的道長(zhǎng)敢会。 經(jīng)常有香客問我曾沈,道長(zhǎng),這世上最難降的妖魔是什么鸥昏? 我笑而不...
    開封第一講書人閱讀 58,204評(píng)論 1 292
  • 正文 為了忘掉前任塞俱,我火速辦了婚禮,結(jié)果婚禮上吏垮,老公的妹妹穿的比我還像新娘障涯。我一直安慰自己罐旗,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,228評(píng)論 6 388
  • 文/花漫 我一把揭開白布唯蝶。 她就那樣靜靜地躺著九秀,像睡著了一般。 火紅的嫁衣襯著肌膚如雪粘我。 梳的紋絲不亂的頭發(fā)上鼓蜒,一...
    開封第一講書人閱讀 51,190評(píng)論 1 299
  • 那天,我揣著相機(jī)與錄音征字,去河邊找鬼都弹。 笑死,一個(gè)胖子當(dāng)著我的面吹牛匙姜,可吹牛的內(nèi)容都是我干的畅厢。 我是一名探鬼主播,決...
    沈念sama閱讀 40,078評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼氮昧,長(zhǎng)吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼框杜!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起袖肥,我...
    開封第一講書人閱讀 38,923評(píng)論 0 274
  • 序言:老撾萬榮一對(duì)情侶失蹤霸琴,失蹤者是張志新(化名)和其女友劉穎,沒想到半個(gè)月后昭伸,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體梧乘,經(jīng)...
    沈念sama閱讀 45,334評(píng)論 1 310
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,550評(píng)論 2 333
  • 正文 我和宋清朗相戀三年庐杨,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了选调。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 39,727評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡灵份,死狀恐怖仁堪,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情填渠,我是刑警寧澤弦聂,帶...
    沈念sama閱讀 35,428評(píng)論 5 343
  • 正文 年R本政府宣布,位于F島的核電站氛什,受9級(jí)特大地震影響莺葫,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜枪眉,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,022評(píng)論 3 326
  • 文/蒙蒙 一捺檬、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧贸铜,春花似錦堡纬、人聲如沸聂受。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,672評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽蛋济。三九已至,卻和暖如春炮叶,著一層夾襖步出監(jiān)牢的瞬間碗旅,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 32,826評(píng)論 1 269
  • 我被黑心中介騙來泰國打工悴灵, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人骂蓖。 一個(gè)月前我還...
    沈念sama閱讀 47,734評(píng)論 2 368
  • 正文 我出身青樓积瞒,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國和親登下。 傳聞我的和親對(duì)象是個(gè)殘疾皇子茫孔,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,619評(píng)論 2 354

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