import requests
# 一,普通的請求方式
# response = requests.get('http://github.com')
# print response.status_code #requests請求的狀態(tài)碼
# print response.url #requests請求的url
# # print response.text #服務(wù)器響應(yīng)的內(nèi)容
# print response.cookies #服務(wù)器響應(yīng)cookie
# print response.headers #服務(wù)器響應(yīng)頭
# print response.encoding #編碼方式初狰,如果源碼沒有指定編碼方式香浩,requests默認ISO-8859-1楷扬,你可以設(shè)置response.encoding = 'utf-8'改變編碼方式。
# print response.raw #獲取來自服務(wù)器的原始套接字響應(yīng)浑娜,請求中設(shè)置stream=True
# print response.history # history 方法來追蹤重定向,是重定向列表享扔,為了完成請求而創(chuàng)建了這些對象底桂。# 這個對象列表按照從最老到最近的請求進行排序。你可以設(shè)置allow_redirects=False禁用請求的重定向功能惧眠。
# 二籽懦,定制請求頭headers,傳遞給requests的headers參數(shù)。
# headers = {
# "":"",
# "":""
# }
# response = requests.get(url,headers=headers)
# 官方文檔描述:
# 注意: 定制 header 的優(yōu)先級低于某些特定的信息源氛魁,例如:
# 如果在 .netrc 中設(shè)置了用戶認證信息暮顺,使用 headers= 設(shè)置的授權(quán)就不會生效。而如果設(shè)置了 auth= 參數(shù)秀存, .netrc 的設(shè)置就無效了捶码。
# 如果被重定向到別的主機,授權(quán) header 就會被刪除或链。
# 代理授權(quán) header 會被 URL 中提供的代理身份覆蓋掉惫恼。
# 在我們能判斷內(nèi)容長度的情況下,header 的 Content-Length 會被改寫澳盐。
# 三祈纯,發(fā)送帶參數(shù)的POST請求令宿,把參數(shù)以字典的形式傳遞給data參數(shù)。
# 如果要求傳遞的參數(shù)是json對象格式:
# 1盆繁、可以直接傳遞給json參數(shù)掀淘,json參數(shù)會自動把payload轉(zhuǎn)換成json對象旬蟋。
# 2油昂、也可以用json.dumps(payload)轉(zhuǎn)換后再傳遞給data參數(shù)。
# payload = {'key1': 'value1', 'key2': 'value2'}
# 不要求參數(shù)是json格式
# response = requests.post('https://api.github.com/some/endpoint',data=payload)
# print response.text
# print response.headers['Status'] #讀取服務(wù)器響應(yīng)頭的Status信息
#要求參數(shù)是json格式倾贰。
# response = requests.post('https://api.github.com/some/endpoint',json=payload)
# 或:
# response = requests.post('https://api.github.com/some/endpoint',data=json.dumps(payload))
# 四冕碟,帶cookies的請求,你需要把cookie傳遞給requests的cookies參數(shù)匆浙。
# cookie = {
# "":"",
# "":""
# }
# response = requests.get(url,cookies=cookie)
# print response.status_code
# 五安寺,鏈接超時,你可以告訴 requests 在經(jīng)過以 timeout 參數(shù)設(shè)定的秒數(shù)時間之后停止等待響應(yīng)首尼√羰基本上所有的生產(chǎn)代碼都應(yīng)該使用這一參數(shù)。如果不使用软能,你的程序可能會永遠失去響應(yīng)迎捺。
# response = requests.get('http://www.baidu.com', timeout=0.01)
# print response.status_code
# 超時會觸發(fā)Timeout 異常。
# timeout 僅對連接過程有效查排,與響應(yīng)體的下載無關(guān)凳枝。 timeout 并不是整個下載響應(yīng)的時間限制,而是如果服務(wù)器在 timeout 秒內(nèi)沒有應(yīng)答跋核,將會引發(fā)一個異常岖瑰。
# (更精確地說,是在 timeout 秒內(nèi)沒有從基礎(chǔ)套接字上接收到任何字節(jié)的數(shù)據(jù)時)
# 六砂代,讀取超時蹋订,讀取超時指的就是客戶端等待服務(wù)器回應(yīng)請求的時間。
# 官方解讀:一旦你的客戶端連接到了服務(wù)器并且發(fā)送了 HTTP 請求刻伊,讀取超時指的就是客戶端等待服務(wù)器發(fā)送請求的時間辅辩。
# (特定地,它指的是客戶端要等待服務(wù)器發(fā)送字節(jié)之間的時間娃圆。在 99.9% 的情況下這指的是服務(wù)器發(fā)送第一個字節(jié)之前的時間)玫锋。
# r = requests.get('https://github.com', timeout=5) #指定了一個單一的值作為 timeout ,將會用作 連接 和 讀取 二者的 timeout讼呢。如果要分別制定撩鹿,就傳入一個元組
# r = requests.get('https://github.com', timeout=(3.05, 27)) #分別設(shè)定連接超時的時間和讀取服務(wù)器回應(yīng)請求的時間,時間最好是3的倍數(shù)多一點。
# r = requests.get('https://github.com', timeout=None) #如果遠端服務(wù)器很慢悦屏,你可以讓 Request 永遠等待节沦,傳入一個 None 作為 timeout 值键思,然后就沖咖啡去吧。會一直等待直到服務(wù)器完成響應(yīng)甫贯。
注:原創(chuàng)文章吼鳞,未經(jīng)作者本人同意,禁止轉(zhuǎn)載叫搁。
原文地址:http://www.reibang.com/p/7445ab23ea0b