您好,登錄后才能下訂單哦!
本篇文章給大家分享的是有關(guān)Python中如何使用requests方法,小編覺得挺實(shí)用的,因此分享給大家學(xué)習(xí),希望大家閱讀完這篇文章后可以有所收獲,話不多說,跟著小編一起來看看吧。
安裝requests
如果安裝了Anaconda,requests就已經(jīng)可用了。否則,需要在命令行下通過pip安裝:
$ pip install requests
如果遇到Permission denied安裝失敗,請(qǐng)加上sudo重試。
使用requests
要通過GET訪問一個(gè)頁面,只需要幾行代碼:
>>> import requests >>> r = requests.get('https://www.douban.com/') # 豆瓣首頁 >>> r.status_code 200 >>> r.text r.text '<!DOCTYPE HTML>\n<html>\n<head>\n<meta name="description" content="提供圖書、電影、音樂唱片的推薦、評(píng)論和...'
對(duì)于帶參數(shù)的URL,傳入一個(gè)dict作為params參數(shù):
>>> r = requests.get('https://www.douban.com/search', params={'q': 'python', 'cat': '1001'}) >>> r.url # 實(shí)際請(qǐng)求的URL'https://www.douban.com/search?q=python&cat=1001'
requests自動(dòng)檢測(cè)編碼,可以使用encoding屬性查看:
>>> r.encoding'utf-8'
無論響應(yīng)是文本還是二進(jìn)制內(nèi)容,我們都可以用content屬性獲得bytes對(duì)象:
>>> r.content b'<!DOCTYPE html>\n<html>\n<head>\n<meta http-equiv="Content-Type" content="text/html; charset=utf-8">\n...' requests的方便之處還在于,對(duì)于特定類型的響應(yīng),例如JSON,可以直接獲?。? >>> r = requests.get(' 20woeid%20%3D%202151330&format=json') >>> r.json() {'query': {'count': 1, 'created': '2017-11-17T07:14:12Z', ...
需要傳入HTTP Header時(shí),我們傳入一個(gè)dict作為headers參數(shù):
>>> r = requests.get('https://www.douban.com/', headers={'User-Agent': 'Mozilla/5.0 (iPhone; CPU iPhone OS 11_0 like Mac OS X) AppleWebKit'}) >>> r.text '<!DOCTYPE html>\n<html>\n<head>\n<meta charset="UTF-8">\n <title>豆瓣(手機(jī)版)</title>...'
要發(fā)送POST請(qǐng)求,只需要把get()方法變成post(),然后傳入data參數(shù)作為POST請(qǐng)求的數(shù)據(jù):
>>> r = requests.post('https://accounts.douban.com/login', data={'form_email': 'abc@example.com', 'form_password': '123456'}) requests默認(rèn)使用application/x-www-form-urlencoded對(duì)POST數(shù)據(jù)編碼。如果要傳遞JSON數(shù)據(jù),可以直接傳入json參數(shù): params = {'key': 'value'}r = requests.post(url, json=params) # 內(nèi)部自動(dòng)序列化為JSON
類似的,上傳文件需要更復(fù)雜的編碼格式,但是requests把它簡(jiǎn)化成files參數(shù):
>>> upload_files = {'file': open('report.xls', 'rb')} >>> r = requests.post(url, files=upload_files)
在讀取文件時(shí),注意務(wù)必使用'rb'即二進(jìn)制模式讀取,這樣獲取的bytes長(zhǎng)度才是文件的長(zhǎng)度。
把post()方法替換為put(),delete()等,就可以以PUT或DELETE方式請(qǐng)求資源。
除了能輕松獲取響應(yīng)內(nèi)容外,requests對(duì)獲取HTTP響應(yīng)的其他信息也非常簡(jiǎn)單。例如,獲取響應(yīng)頭:
>>> r.headers {Content-Type': 'text/html; charset=utf-8', 'Transfer-Encoding': 'chunked', 'Content-Encoding': 'gzip', ...} >>> r.headers['Content-Type'] 'text/html; charset=utf-8'
requests對(duì)Cookie做了特殊處理,使得我們不必解析Cookie就可以輕松獲取指定的Cookie:
>>> r.cookies['ts']'example_cookie_12345'
要在請(qǐng)求中傳入Cookie,只需準(zhǔn)備一個(gè)dict傳入cookies參數(shù):
>>> cs = {'token': '12345', 'status': 'working'} >>> r = requests.get(url, cookies=cs)
最后,要指定超時(shí),傳入以秒為單位的timeout參數(shù):
>>> r = requests.get(url, timeout=2.5) # 2.5秒后超時(shí)
以上就是Python中如何使用requests方法,小編相信有部分知識(shí)點(diǎn)可能是我們?nèi)粘9ぷ鲿?huì)見到或用到的。希望你能通過這篇文章學(xué)到更多知識(shí)。更多詳情敬請(qǐng)關(guān)注億速云行業(yè)資訊頻道。
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。