python中requests模塊的使用方法
本文實例講述了python中requests模塊的使用方法。分享給大家供大家參考。具體分析如下:
在HTTP相關(guān)處理中使用python是不必要的麻煩,這包括urllib2模塊以巨大的復(fù)雜性代價獲取綜合性的功能。相比于urllib2,Kenneth Reitz的Requests模塊更能簡約的支持完整的簡單用例。
簡單的例子:
想象下我們試圖使用get方法從http://example.test/獲取資源并且查看返回代碼,content-type頭信息,還有response的主體內(nèi)容。這件事無論使用urllib2 或者Requests都是很容易實現(xiàn)的。
urllib2
>>> import urllib2 >>> url = 'http://example.test/' >>> response = urllib2.urlopen(url) >>> response.getcode() 200 >>> response.headers.getheader('content-type') 'text/html; charset=utf-8' >>> response.read() 'Hello, world!'
Requests
>>> import requests >>> url = 'http://example.test/' >>> response = requests.get(url) >>> response.status_code 200 >>> response.headers['content-type'] 'text/html; charset=utf-8' >>> response.content u'Hello, world!'
這兩種方法很相似,相對于urllib2調(diào)用方法讀取response中的屬性信息,Requests則是使用屬性名來獲取對應(yīng)的屬性值。
兩者還有兩個細(xì)微但是很重要的差別:
1 Requests 自動的把返回信息有Unicode解碼
2 Requests 自動保存了返回內(nèi)容,所以你可以讀取多次,而不像urllib2.urlopen()那樣返回的只是一個類似文件類型只能讀取一次的對象。
第二點是在python交互式環(huán)境下操作代碼很令人討厭的事情
一個復(fù)雜一點的例子:
現(xiàn)在讓我們嘗試下復(fù)雜點得例子:使用GET方法獲取http://foo.test/secret的資源,這次需要基本的http驗證。使用上面的代碼作為模板,好像我們只要把urllib2.urlopen() 到requests.get()之間的代碼換成可以發(fā)送username,password的請求就行了
這是urllib2的方法:
>>> import urllib2 >>> url = 'http://example.test/secret' >>> password_manager = urllib2.HTTPPasswordMgrWithDefaultRealm() >>> password_manager.add_password(None, url, 'dan', 'h0tdish') >>> auth_handler = urllib2.HTTPBasicAuthHandler(password_manager) >>> opener = urllib2.build_opener(auth_handler) >>> urllib2.install_opener(opener) >>> response = urllib2.urlopen(url) >>> response.getcode() 200 >>> response.read() 'Welcome to the secret page!'
一個簡單的方法中實例化了2個類,然后組建了第三個類,最后還要裝載到全局的urllib2模塊中,最后才調(diào)用了urlopen,那么那兩個復(fù)雜的類是什么的
迷惑了嗎, 這里所有urllib2的文檔 http://docs.python.org/release/2.7/library/urllib2.html
那Requests是怎么樣解決同樣的問題的呢?
Requests
>>> import requests >>> url = 'http://example.test/secret' >>> response = requests.get(url,auth=('dan','h0tdish')) >>> response.status_code 200 >>> response.content u'Welcome to the secret page!'
只是在調(diào)用方法的時候增加了一個auth關(guān)鍵字函數(shù)
我敢打賭你不用查文檔也能記住。
錯誤處理 Error Handling
Requests對錯誤的處理也是很非常方面。如果你使用了不正確的用戶名和密碼,urllib2會引發(fā)一個urllib2.URLError錯誤,然而Requests會像你期望的那樣返回一個正常的response對象。只需查看response.ok的布爾值便可以知道是否登陸成功。
>>> response = requests.get(url,auth=('dan','wrongPass')) >>> response.ok False
其他的一些特性:
* Requests對于HEAD, POST, PUT, PATCH, 和 DELETE方法的api同樣簡單
* 它可以處理多部分上傳,同樣支持自動轉(zhuǎn)碼
* 文檔更好
* 還有更多
Requests 是很好的,下次需要使用HTTP時候可以試試。
希望本文所述對大家的Python程序設(shè)計有所幫助。
- python中requests庫session對象的妙用詳解
- python采用requests庫模擬登錄和抓取數(shù)據(jù)的簡單示例
- Python使用requests發(fā)送POST請求實例代碼
- python中requests使用代理proxies方法介紹
- python?如何使用requests下載文件
- Python爬蟲庫requests獲取響應(yīng)內(nèi)容、響應(yīng)狀態(tài)碼、響應(yīng)頭
- Python3使用requests包抓取并保存網(wǎng)頁源碼的方法
- 詳解Python requests 超時和重試的方法
- Python requests timeout的設(shè)置
- 解決Python requests 報錯方法集錦
- Python中Requests庫的實現(xiàn)示例
相關(guān)文章
Python多進(jìn)程入門、分布式進(jìn)程數(shù)據(jù)共享實例詳解
這篇文章主要介紹了Python多進(jìn)程入門、分布式進(jìn)程數(shù)據(jù)共享,結(jié)合實例形式詳細(xì)分析了Python進(jìn)程操作技巧數(shù)據(jù)共享相關(guān)實現(xiàn)技巧與注意事項,需要的朋友可以參考下2019-06-06詳解Python匿名函數(shù)(lambda函數(shù))
這篇文章主要介紹了Python匿名函數(shù)(lambda函數(shù)),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2019-04-04利用python、tensorflow、opencv、pyqt5實現(xiàn)人臉實時簽到系統(tǒng)
這篇文章主要介紹了利用python、tensorflow、opencv、pyqt5實現(xiàn)人臉實時簽到系統(tǒng),本文給大家介紹的非常詳細(xì),具有一定的參考借鑒價值,需要的朋友可以參考下2019-09-09Python如何聲明以管理員方式運行(附實戰(zhàn)案例)
由于Windows的安全機制,Python寫的腳本缺少了管理員權(quán)限,運行就會受到一些限制,這篇文章主要介紹了Python如何聲明以管理員方式運行的相關(guān)資料,文中通過代碼介紹的非常詳細(xì),需要的朋友可以參考下2025-04-04如何用 Python 子進(jìn)程關(guān)閉 Excel 自動化中的彈窗
這篇文章主要介紹了如何用 Python 子進(jìn)程關(guān)閉 Excel 自動化中的彈窗,幫助大家更好的理解和學(xué)習(xí)使用python,感興趣的朋友可以了解下2021-05-05