日韩无码专区无码一级三级片|91人人爱网站中日韩无码电影|厨房大战丰满熟妇|AV高清无码在线免费观看|另类AV日韩少妇熟女|中文日本大黄一级黄色片|色情在线视频免费|亚洲成人特黄a片|黄片wwwav色图欧美|欧亚乱色一区二区三区

RELATEED CONSULTING
相關(guān)咨詢
選擇下列產(chǎn)品馬上在線溝通
服務(wù)時(shí)間:8:30-17:00
你可能遇到了下面的問題
關(guān)閉右側(cè)工具欄

新聞中心

這里有您想知道的互聯(lián)網(wǎng)營(yíng)銷解決方案
Python3中進(jìn)行HTTP請(qǐng)求的4種方式

python包索引(PyPI)提供了超過10萬(wàn)個(gè)代碼庫(kù)的包,它能夠幫助python程序員完成許多工作,無(wú)論是構(gòu)建web應(yīng)用程序還是分析數(shù)據(jù)。另外PyPI還提供了很多諸如 twilio 之類的API的輔助庫(kù)。

下面讓我們通過使用4個(gè)不同的 Python HTTP 庫(kù)來(lái)學(xué)習(xí)如何從 RESTful API 檢索和解析 JSON 數(shù)據(jù),以此來(lái)演示PyPI包的強(qiáng)大功能。

文中的每個(gè)示例都包含以下內(nèi)容:

  1. 定義要解析的URL,我們將使用Spotify API,因?yàn)樗恍枰谡?qǐng)求時(shí)進(jìn)行身份驗(yàn)證。
  2. 創(chuàng)建一個(gè) HTTP GET 去請(qǐng)求這個(gè)URL。
  3. 解析返回的JSON數(shù)據(jù)。

我們將要使用的四個(gè)庫(kù)用了不同的方法得到同一個(gè)結(jié)果。如果你把結(jié)果輸出,將會(huì)看到一個(gè)有Spotify搜索結(jié)果的字典:

*注意:結(jié)果可能會(huì)根據(jù)你使用的Python版本而有所不同。在這篇文章中,所有的代碼都使用Python 3編寫。 如果你仍在使用Python 2.X,那么請(qǐng)考慮為Python 3設(shè)置一個(gè)virtualenv。

以下說明將幫助您使用virtualenv與Python 3:

  1. 為Python 3測(cè)試創(chuàng)建一個(gè)名為pythreetest的目錄。
  2. 一旦安裝了virtualenv,從項(xiàng)目目錄中執(zhí)行以下命令:

使用以下命令創(chuàng)建一個(gè)新的virtualenv:

 
 
 
 
  1. virtualenv -p python3 myvenv 

使用source命令激活myvenv:

 
 
 
 
  1. source myvenv/bin/activate 

現(xiàn)在你將能夠使用pip安裝需要的庫(kù),并在virtualenv中使用Python 3啟動(dòng)解釋器,在那里您可以成功導(dǎo)入包。

urllib

urllib是一個(gè)內(nèi)置在Python標(biāo)準(zhǔn)庫(kù)中的模塊,并使用http.client來(lái)實(shí)現(xiàn)HTTP和HTTPS協(xié)議的客戶端。 由于urllib是同Python一起進(jìn)行分發(fā)和安裝的,因此無(wú)需使用 pip 進(jìn)行安裝。 如果你重視穩(wěn)定性,那么這就是給你準(zhǔn)備的。 twilio-python助手庫(kù)就使用了urllib。

urllib同其他庫(kù)比起來(lái)需要做更多的工作。 例如:你必須在發(fā)出HTTP請(qǐng)求之前創(chuàng)建一個(gè)URL對(duì)象。

 
 
 
 
  1. import urllib.request 
  2. import urllib.parse 
  3.  
  4. url = 'https://api.spotify.com/v1/search?type=artist&q=snoop' 
  5. f = urllib.request.urlopen(url) 
  6. print(f.read().decode('utf-8'))  

在上面的例子中,我們將請(qǐng)求URL發(fā)送到CGI的stdin,并讀取返回給我們的數(shù)據(jù)。

Requests

Requests是Python社區(qū)中最喜歡的庫(kù),因?yàn)樗?jiǎn)潔易用。 Requests由urllib3提供支持,有玩笑說這是“唯一的非轉(zhuǎn)基因HTTP庫(kù),適合人類消費(fèi)”。

Requests 抽象了大量的程式化的代碼,使得HTTP請(qǐng)求比使用內(nèi)置urllib庫(kù)更簡(jiǎn)單。

首先用pip進(jìn)行安裝

 
 
 
 
  1. pip install requests 

向 Spotify 發(fā)送請(qǐng)求

 
 
 
 
  1. import requests 
  2.  
  3. r = requests.get('https://api.spotify.com/v1/search?type=artist&q=snoop') 
  4.  
  5. r.json()  

輸出結(jié)果:

 
 
 
 
  1. from pprint import pprint 
  2.  
  3. pprint(r.json())  

我們剛剛向Spotify發(fā)出了一個(gè)GET請(qǐng)求,同時(shí)創(chuàng)建了一個(gè)名為r的Response 對(duì)象,之后使用內(nèi)置的JSON解碼器來(lái)處理我們請(qǐng)求的內(nèi)容。

Octopus

Octopus是為想要GET一切的開發(fā)人員準(zhǔn)備的。它允許你多任務(wù)去訪問Spotify。就像它的名字一樣,這個(gè)庫(kù)使用線程并發(fā)地檢索和報(bào)告HTTP請(qǐng)求的完成情況,同時(shí)可以使用你所熟悉的庫(kù)。

或者,你可以使用 Tornado 的 IOLoop 進(jìn)行異步請(qǐng)求,不過在這里就不盡興嘗試了。

通過pip安裝:

 
 
 
 
  1. pip install octopus-http 

Octopus的設(shè)置比前面的例子稍微多一些。 我們必須構(gòu)建一個(gè)響應(yīng)處理器,并使用內(nèi)置的JSON庫(kù)對(duì)JSON進(jìn)行編碼。

 
 
 
 
  1. import json 
  2.   
  3. from pprint import pprint 
  4. from octopus import Octopus 
  5.   
  6.   
  7. def create_request(urls): 
  8.     data = [] 
  9.   
  10.     otto = Octopus( 
  11.            concurrency=4, auto_start=True, cache=True, expiration_in_seconds=10 
  12.     ) 
  13.   
  14.     def handle_url_response(url, response): 
  15.         if "Not found" == response.text: 
  16.             print ("URL Not Found: %s" % url) 
  17.         else: 
  18.             data.append(response.text) 
  19.   
  20.     for url in urls: 
  21.         otto.enqueue(url, handle_url_response) 
  22.   
  23.     otto.wait() 
  24.   
  25.     json_data = json.JSONEncoder(indent=None, 
  26.                                  separators=(',', ': ')).encode(data) 
  27.   
  28.     return pprint(json_data) 
  29.   
  30.   
  31. print(create_request(['https://api.spotify.com/v1/search?type=artist&q=snoop', 
  32.                      'https://api.spotify.com/v1/search?type=artist&q=dre']))  

在上面的代碼片段中,我們定義了create_requests函數(shù)來(lái)使用線程Octopus請(qǐng)求。 我們從一個(gè)空的list開始,data,并創(chuàng)建Octopus類的一個(gè)實(shí)例dotto。 最后配置了默認(rèn)設(shè)置。

然后我們構(gòu)建響應(yīng)處理器,其中的response參數(shù)是Octopus.Response的一個(gè)實(shí)例。 當(dāng)每個(gè)請(qǐng)求成功后,響應(yīng)內(nèi)容將被添加到數(shù)據(jù)列表中。在響應(yīng)處理器內(nèi)部,我們可以使用Octopus類的主要方法。.enqueue方法用于加入新的URL。

我們指定.wait方法等待隊(duì)列中的所有URL完成加載,然后對(duì)JSON列表進(jìn)行JSON編碼并打印結(jié)果。

吁,終于結(jié)束了。

HTTPie

HTTPie適用于希望快速與HTTP服務(wù)器、RESTful API 和 Web 服務(wù)進(jìn)行交互的開發(fā)人員,它僅僅需要一行代碼。 這個(gè)庫(kù)是“一個(gè)可以讓你微笑的開源 CLI HTTP客戶端:用戶友好的 curl 替代方案”。雖然它可以不依賴Python環(huán)境,但是它可以通過Pip安裝,并用來(lái)創(chuàng)建HTTP請(qǐng)求。

 
 
 
 
  1. pip install httpie 

默認(rèn)協(xié)議是HTTP,但您可以創(chuàng)建一個(gè)別名,并重置HTTPS為默認(rèn)值,如下所示:

 
 
 
 
  1. alias https='http —default-scheme=https' 

之后創(chuàng)建請(qǐng)求:

 
 
 
 
  1. https "https://api.spotify.com/v1/search?type=artist&q=snoop" 

使用HTTPie僅需要URL就夠了。

最后的想法

Python 生態(tài)提供了許多與 JSON api 交互的選擇。雖然這些方法對(duì)于最簡(jiǎn)單的請(qǐng)求是相似的, 但隨著 HTTP 請(qǐng)求的復(fù)雜性增加, 這些差異變得更加明顯。多進(jìn)行嘗試, 看看哪一個(gè)最適合你的需求。你甚至可以嘗試用另一種語(yǔ)言, 如 Ruby。


分享文章:Python3中進(jìn)行HTTP請(qǐng)求的4種方式
網(wǎng)頁(yè)網(wǎng)址:http://m.5511xx.com/article/dhccoje.html