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