網站首頁 編程語言 正文
一、說明
requests是一個很實用的Python HTTP客戶端庫,爬蟲和測試服務器響應數據時經常會用到,requests是Python語言的第三方的庫,專門用于發送HTTP請求,使用起來比urllib簡潔很多。
Requests 有這些功能:
1、Keep-Alive & 連接池
2、國際化域名和 URL
3、帶持久 Cookie 的會話
4、瀏覽器式的 SSL 認證
5、自動內容解碼
6、基本/摘要式的身份認證
7、優雅的 key/value Cookie
8、自動解壓
9、Unicode 響應體
10、HTTP(S) 代理支持
11、文件分塊上傳
12、流下載
13、連接超時
14、分塊請求
15、支持 .netrc
Requests 支持 Python 2.6—2.7以及3.3—3.7,而且能在 PyPy 下完美運行。
用pip進行第三方庫的安裝
pip install requests
安裝完成后import一下,正常則說明可以開始使用了。
二、基本用法:
1、requests.get()
用于請求目標網站,類型是一個HTTPresponse類型
import requests response = requests.get('http://www.baidu.com') print(response.status_code) # 打印狀態碼 print(response.url) # 打印請求url print(response.headers) # 打印頭信息 print(response.cookies) # 打印cookie信息 print(response.text) #以文本形式打印網頁源碼 print(response.content) #以字節流形式打印 print(response.content.decode("utf-8")) #解決了通過response.text直接返回顯示亂碼的問題 response.encoding="utf-8" #避免亂碼的問題發生
2、各種請求方式
import requests requests.get('http://httpbin.org/get') requests.post('http://httpbin.org/post') requests.put('http://httpbin.org/put') requests.delete('http://httpbin.org/delete') requests.head('http://httpbin.org/get') requests.options('http://httpbin.org/get')
3、基本的get請求
import requests response = requests.get('http://httpbin.org/get') print(response.text)
4、帶參數的get請求
第一種直接將參數放在url內
import requests response = requests.get(http://httpbin.org/get?name=gemey&age=22) print(response.text)
另一種先將參數填寫在dict中,發起請求時params參數指定為dict
import requests data = { 'name': 'tom', 'age': 20 } response = requests.get('http://httpbin.org/get', params=data) print(response.text)
5、解析json
import requests response = requests.get('http://httpbin.org/get') print(response.text) print(response.json()) #response.json()方法同json.loads(response.text) print(type(response.json()))
如果 JSON 解碼失敗, 將會拋出 ValueError: No JSON object could be decoded 異常。而成功調用 response.json() 并不意味著響應的成功。有的服務器會在失敗的響應中包含一個 JSON 對象(比如 HTTP 500 的錯誤細節)。這種 JSON 會被解碼返回。要檢查請求是否成功,請使用 r.raise_for_status() 或者檢查 response.status_code 是否和你的期望相同
6、保存一個二進制文件
二進制內容為response.content
import requests response = requests.get('http://img.ivsky.com/img/tupian/pre/201708/30/kekeersitao-002.jpg') b = response.content with open('F://fengjing.jpg','wb') as f: f.write(b)
7、添加heads信息
import requests heads = {} heads['User-Agent'] = 'Mozilla/5.0 ' \ '(Macintosh; U; Intel Mac OS X 10_6_8; en-us) AppleWebKit/534.50 ' \ '(KHTML, like Gecko) Version/5.1 Safari/534.50' response = requests.get('http://www.baidu.com',headers=headers)
8、使用代理
同添加headers方法,代理參數也要是一個dict
這里使用requests庫爬取了IP代理網站的IP與端口和類型
import requests import re def get_html(url): proxy = { 'http': '120.25.253.234:812', 'https': '163.125.222.244:8123' } heads = {} heads['User-Agent'] = 'Mozilla/5.0 (Windows NT 10.0; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/49.0.2623.221 Safari/537.36 SE 2.X MetaSr 1.0' req = requests.get(url, headers=heads,proxies=proxy) html = req.text return html def get_ipport(html): regex = r'<td data-title="IP">(.+)</td>' iplist = re.findall(regex, html) regex2 = '<td data-title="PORT">(.+)</td>' portlist = re.findall(regex2, html) regex3 = r'<td data-title="類型">(.+)</td>' typelist = re.findall(regex3, html) sumray = [] for i in iplist: for p in portlist: for t in typelist: pass pass a = t+','+i + ':' + p sumray.append(a) print('高匿代理') print(sumray) if __name__ == '__main__': url = 'http://www.kuaidaili.com/free/' get_ipport(get_html(url))
9、基本POST請求
import requests data = {'name':'tom','age':'22'} response = requests.post('http://httpbin.org/post', data=data)
10、獲取cookie
import requests response = requests.get('http://www.baidu.com') print(response.cookies) print(type(response.cookies)) for k,v in response.cookies.items(): print(k+':'+v)
11、會話維持
import requests session = requests.Session() session.get('http://httpbin.org/cookies/set/number/12345') response = session.get('http://httpbin.org/cookies') print(response.text)
11、證書驗證設置
import requests from requests.packages import urllib3 urllib3.disable_warnings() #從urllib3中消除警告 response = requests.get('https://www.12306.cn',verify=False) #證書驗證設為FALSE print(response.status_code)
12、超時異常捕獲
import requests from requests.exceptions import ReadTimeout try: res = requests.get('http://httpbin.org', timeout=0.1) print(res.status_code) except ReadTimeout: print(timeout)
13、異常處理
在你不確定會發生什么錯誤時,盡量使用try…except來捕獲異常
import requests from requests.exceptions import ReadTimeout,HTTPError,RequestException try: response = requests.get('http://www.baidu.com',timeout=0.5) print(response.status_code) except ReadTimeout: print('timeout') except HTTPError: print('httperror') except RequestException: print('reqerror')
總結
原文鏈接:https://blog.csdn.net/s_unbo/article/details/122829112
相關推薦
- 2022-06-21 Android?studio實現兩個界面間的切換_Android
- 2022-04-18 html2canvas 不支持圖片的object-fit樣式
- 2022-12-14 Jetpack?Compose?雙指拖拽實現詳解_Android
- 2022-10-10 C++超詳細分析type_traits_C 語言
- 2022-05-23 Python學習之時間包使用教程詳解_python
- 2022-02-26 Android操作SQLite基本用法_Android
- 2022-05-29 C#獲取攝像頭拍照顯示圖像的方法_C#教程
- 2022-02-09 深入了解C++異常處理_C 語言
- 最近更新
-
- window11 系統安裝 yarn
- 超詳細win安裝深度學習環境2025年最新版(
- Linux 中運行的top命令 怎么退出?
- MySQL 中decimal 的用法? 存儲小
- get 、set 、toString 方法的使
- @Resource和 @Autowired注解
- Java基礎操作-- 運算符,流程控制 Flo
- 1. Int 和Integer 的區別,Jav
- spring @retryable不生效的一種
- Spring Security之認證信息的處理
- Spring Security之認證過濾器
- Spring Security概述快速入門
- Spring Security之配置體系
- 【SpringBoot】SpringCache
- Spring Security之基于方法配置權
- redisson分布式鎖中waittime的設
- maven:解決release錯誤:Artif
- restTemplate使用總結
- Spring Security之安全異常處理
- MybatisPlus優雅實現加密?
- Spring ioc容器與Bean的生命周期。
- 【探索SpringCloud】服務發現-Nac
- Spring Security之基于HttpR
- Redis 底層數據結構-簡單動態字符串(SD
- arthas操作spring被代理目標對象命令
- Spring中的單例模式應用詳解
- 聊聊消息隊列,發送消息的4種方式
- bootspring第三方資源配置管理
- GIT同步修改后的遠程分支