Requests是python的一個(gè)HTTP客戶端庫,跟urllib,urllib2類似。它比urllib更加方便,可以節(jié)約我們大量的工作,它比urllib更加Pythoner。
安裝Requests
通過pip安裝
$pipinstallrequests
或者,下載代碼后安裝:
$wgethttps://github.com/requests/requests/tarball/master
$mvmasterrequests.tgz
$tarxzfrequests.tgz
$cdrequests-requests-3dc84cd
$pythonsetup.pyinstall
發(fā)送請(qǐng)求
使用Requests發(fā)送網(wǎng)絡(luò)請(qǐng)求非常簡單。
>>>importrequests#導(dǎo)入Requests模塊
>>>result=requests.get('http://www.pythontab.com')#生成Response對(duì)象
>>>result.status_code#返回碼
200
>>>result.headers['content-type']#返回頭部信息
'text/html;charset=utf8'
>>>result.encoding#編碼信息
'utf-8'
>>>result.content#內(nèi)容部分
為URL傳遞參數(shù)
你也許經(jīng)常想為URL的查詢字符串(querystring)傳遞某種數(shù)據(jù)。如果你是手工構(gòu)建URL,那么數(shù)據(jù)會(huì)以鍵/值對(duì)的形式置于URL中,跟在一個(gè)問號(hào)的后面。例如,www.pythontab.com?version=python3。Requests允許你使用params關(guān)鍵字參數(shù),以一個(gè)字典來提供這些參數(shù)。舉例來說,如果你想傳遞version=python3和keywords=pythontab到www.pythontab.com,那么你可以使用如下代碼:
>>>data={'version':'python3','keywords':'pythontab'}
>>>result=requests.get("http://www.pythontab.com",params=data)
>>>printresult.status_code
200
原始響應(yīng)內(nèi)容
在罕見的情況下你可能想獲取來自服務(wù)器的原始套接字響應(yīng),那么你可以訪問r.raw。如果你確實(shí)想這么干,那請(qǐng)你確保在初始請(qǐng)求中設(shè)置了stream=True。具體的你可以這么做:
>>>result=requests.get('http://www.pythontab.com',stream=True)
>>>result.raw
>>>result.raw.read(10)
'\x1f\x8b\x08\x00\x00\x00\x00\x00\x00\x03'
定制請(qǐng)求頭
如果你想為請(qǐng)求添加HTTP頭部,只要簡單地傳遞一個(gè)dict給headers參數(shù)就可以了。
例如,在前一個(gè)示例中我們沒有指定content-type:
>>>importrequests
>>>url='http://www.pythontab.com'
>>>data={'version':'python3','keywords':'pythontab'}
>>>headers={'content-type':'application/json'}
>>>result=requests.post(url,data=json.dumps(data),headers=headers)
錯(cuò)誤與異常
遇到網(wǎng)絡(luò)問題(如:DNS查詢失敗、拒絕連接等)時(shí),Requests會(huì)拋出一個(gè)ConnectionError異常。
遇到罕見的無效HTTP響應(yīng)時(shí),Requests則會(huì)拋出一個(gè)HTTPError異常。
若請(qǐng)求超時(shí),則拋出一個(gè)Timeout異常。
若請(qǐng)求超過了設(shè)定的最大重定向次數(shù),則會(huì)拋出一個(gè)TooManyRedirects異常。
所有Requests顯式拋出的異常都繼承自requests.exceptions.RequestException。
其他常用方法
result.content#獲取二進(jìn)制響應(yīng)內(nèi)容
result.json()#JSON響應(yīng)內(nèi)容
result.headers#響應(yīng)頭內(nèi)容
result.cookies#cookie內(nèi)容
result.history#請(qǐng)求歷史
以上內(nèi)容為大家介紹了PythonRequests模塊快速入門,希望對(duì)大家有所幫助,如果想要了解更多Python相關(guān)知識(shí),請(qǐng)關(guān)注IT培訓(xùn)機(jī)構(gòu):千鋒教育。http://m.fengjieshuijing.cn/