python request 模塊詳細(xì)介紹
request
Requests 是使用 Apache2 Licensed 許可證的 基于Python開(kāi)發(fā)的HTTP 庫(kù),其在Python內(nèi)置模塊的基礎(chǔ)上進(jìn)行了高度的封裝,從而使得Pythoner進(jìn)行網(wǎng)絡(luò)請(qǐng)求時(shí),變得美好了許多,使用Requests可以輕而易舉的完成瀏覽器可有的任何操作。
GET 請(qǐng)求
# 1、無(wú)參數(shù)實(shí)例
import requests
ret = requests.get('https://github.com/timeline.json')
print ret.url
print ret.text
# 2、有參數(shù)實(shí)例
import requests
payload = {'key1': 'value1', 'key2': 'value2'}
ret = requests.get("http://httpbin.org/get", params=payload)
print ret.url
print ret.text
POST 請(qǐng)求
# 1、基本POST實(shí)例
import requests
payload = {'key1': 'value1', 'key2': 'value2'}
ret = requests.post("http://httpbin.org/post", data=payload)
print ret.text
# 2、發(fā)送請(qǐng)求頭和數(shù)據(jù)實(shí)例
import requests
import json
url = 'https://api.github.com/some/endpoint'
payload = {'some': 'data'}
headers = {'content-type': 'application/json'}
ret = requests.post(url, data=json.dumps(payload), headers=headers)
print ret.text
print ret.cookies
其他請(qǐng)求
requests.get(url, params=None, **kwargs) requests.post(url, data=None, json=None, **kwargs) requests.put(url, data=None, **kwargs) requests.head(url, **kwargs) requests.delete(url, **kwargs) requests.patch(url, data=None, **kwargs) requests.options(url, **kwargs) # 以上方法均是在此方法的基礎(chǔ)上構(gòu)建 requests.request(method, url, **kwargs)
requests.request() 參數(shù)
method:提交方式 get/post 。
url:提交地址。
params:在URL上傳遞的參數(shù),GET形式傳遞到后臺(tái),例如向http://www.oldboyyede.com上傳數(shù)據(jù)。
requests.request(
method = 'GET',
url = 'http://www.oldboyyede.com',
params = { 'k1' : 'v1' , 'k2' : 'v2' }
)
# http://www.oldboyyede.com?k1=v1&k2=v2
data:在請(qǐng)求體里面?zhèn)鬟f的數(shù)據(jù),后面可以是字典,字節(jié)等數(shù)據(jù)類(lèi)型。
requests.request(
method = 'POST',
url = 'http://www.oldboyyede.com',
# data= { 'k1' : 'v1' , 'k2' : 'v2' , 'x':[1,2,3]}
data=" user=wjw&pwd=123123 "
)
json:在請(qǐng)求體里面?zhèn)鬟f數(shù)據(jù),把整體序列化成一個(gè)大字符串,字典中嵌套字典的話用JSON 。
requests.request(
method = 'POST',
url = 'http://www.oldboyyede.com',
json= { 'k1' : 'v1' , 'k2' : 'v2' }
)
# "{ 'k1' : 'v1' , 'k2' : 'v2' }"
headers:請(qǐng)求頭。
一定要添加瀏覽器,不然可能會(huì)遇到網(wǎng)絡(luò)防火墻

headers = {'User-Agent': 'Mozilla/5.0 (Windows NT 10.0; WOW64; rv:58.0) Gecko/20100101 Firefox/58.0'}
# 一定要添加瀏覽器,不然可能會(huì)遇到網(wǎng)絡(luò)防火墻攔截你的請(qǐng)求
headers = {'User-Agent': 'Mozilla/5.0 (Windows NT 10.0; WOW64; rv:58.0) Gecko/20100101 Firefox/58.0'}
r1 = requests.get(
url='http://dig.chouti.com/',
headers=headers
)
files:上傳文件對(duì)象。
# 模塊的詳細(xì)使用
import requests
requests.post(
url='xxxxxx',
files={
# 'f1':open('s1.py','rb')
# 可以上傳元祖的形式上傳,sssss1.py為后臺(tái)獲取的名稱(chēng)
'f1': open('sssss1.py',('s1.py', 'rb'))
}
)
參數(shù)實(shí)例
def param_method_url():
# requests.request(method='get', url='http://127.0.0.1:8000/test/')
# requests.request(method='post', url='http://127.0.0.1:8000/test/')
pass
def param_param():
# - 可以是字典
# - 可以是字符串
# - 可以是字節(jié)(ascii編碼以?xún)?nèi))
# requests.request(method='get',
# url='http://127.0.0.1:8000/test/',
# params={'k1': 'v1', 'k2': '水電費(fèi)'})
# requests.request(method='get',
# url='http://127.0.0.1:8000/test/',
# params="k1=v1&k2=水電費(fèi)&k3=v3&k3=vv3")
# requests.request(method='get',
# url='http://127.0.0.1:8000/test/',
# params=bytes("k1=v1&k2=k2&k3=v3&k3=vv3", encoding='utf8'))
# 錯(cuò)誤
# requests.request(method='get',
# url='http://127.0.0.1:8000/test/',
# params=bytes("k1=v1&k2=水電費(fèi)&k3=v3&k3=vv3", encoding='utf8'))
pass
def param_data():
# 可以是字典
# 可以是字符串
# 可以是字節(jié)
# 可以是文件對(duì)象
# requests.request(method='POST',
# url='http://127.0.0.1:8000/test/',
# data={'k1': 'v1', 'k2': '水電費(fèi)'})
# requests.request(method='POST',
# url='http://127.0.0.1:8000/test/',
# data="k1=v1; k2=v2; k3=v3; k3=v4"
# )
# requests.request(method='POST',
# url='http://127.0.0.1:8000/test/',
# data="k1=v1;k2=v2;k3=v3;k3=v4",
# headers={'Content-Type': 'application/x-www-form-urlencoded'}
# )
# requests.request(method='POST',
# url='http://127.0.0.1:8000/test/',
# data=open('data_file.py', mode='r', encoding='utf-8'), # 文件內(nèi)容是:k1=v1;k2=v2;k3=v3;k3=v4
# headers={'Content-Type': 'application/x-www-form-urlencoded'}
# )
pass
def param_json():
# 將json中對(duì)應(yīng)的數(shù)據(jù)進(jìn)行序列化成一個(gè)字符串,json.dumps(...)
# 然后發(fā)送到服務(wù)器端的body中,并且Content-Type是 {'Content-Type': 'application/json'}
requests.request(method='POST',
url='http://127.0.0.1:8000/test/',
json={'k1': 'v1', 'k2': '水電費(fèi)'})
def param_headers():
# 發(fā)送請(qǐng)求頭到服務(wù)器端
requests.request(method='POST',
url='http://127.0.0.1:8000/test/',
json={'k1': 'v1', 'k2': '水電費(fèi)'},
headers={'Content-Type': 'application/x-www-form-urlencoded'}
)
def param_cookies():
# 發(fā)送Cookie到服務(wù)器端
requests.request(method='POST',
url='http://127.0.0.1:8000/test/',
data={'k1': 'v1', 'k2': 'v2'},
cookies={'cook1': 'value1'},
)
# 也可以使用CookieJar(字典形式就是在此基礎(chǔ)上封裝)
from http.cookiejar import CookieJar
from http.cookiejar import Cookie
obj = CookieJar()
obj.set_cookie(Cookie(version=0, name='c1', value='v1', port=None, domain='', path='/', secure=False, expires=None,
discard=True, comment=None, comment_url=None, rest={'HttpOnly': None}, rfc2109=False,
port_specified=False, domain_specified=False, domain_initial_dot=False, path_specified=False)
)
requests.request(method='POST',
url='http://127.0.0.1:8000/test/',
data={'k1': 'v1', 'k2': 'v2'},
cookies=obj)
def param_files():
# 發(fā)送文件
# file_dict = {
# 'f1': open('readme', 'rb')
# }
# requests.request(method='POST',
# url='http://127.0.0.1:8000/test/',
# files=file_dict)
# 發(fā)送文件,定制文件名
# file_dict = {
# 'f1': ('test.txt', open('readme', 'rb'))
# }
# requests.request(method='POST',
# url='http://127.0.0.1:8000/test/',
# files=file_dict)
# 發(fā)送文件,定制文件名
# file_dict = {
# 'f1': ('test.txt', "hahsfaksfa9kasdjflaksdjf")
# }
# requests.request(method='POST',
# url='http://127.0.0.1:8000/test/',
# files=file_dict)
# 發(fā)送文件,定制文件名
# file_dict = {
# 'f1': ('test.txt', "hahsfaksfa9kasdjflaksdjf", 'application/text', {'k1': '0'})
# }
# requests.request(method='POST',
# url='http://127.0.0.1:8000/test/',
# files=file_dict)
pass
<br>
# 做基本認(rèn)證 header中加密的用戶(hù)名和密碼
def param_auth():
from requests.auth import HTTPBasicAuth, HTTPDigestAuth
ret = requests.get('https://api.github.com/user', auth=HTTPBasicAuth('wangjiawei', 'sdfasdfasdf'))
print(ret.text)
# ret = requests.get('http://192.168.1.1',
# auth=HTTPBasicAuth('admin', 'admin'))
# ret.encoding = 'gbk'
# print(ret.text)
# ret = requests.get('http://httpbin.org/digest-auth/auth/user/pass', auth=HTTPDigestAuth('user', 'pass'))
# print(ret)
#
# 請(qǐng)求和響應(yīng)的超時(shí)時(shí)間
def param_timeout():
# ret = requests.get('http://google.com/', timeout=1)
# print(ret)
# ret = requests.get('http://google.com/', timeout=(5, 1))
# print(ret)
pass
<br>
# 是允許否重定向
def param_allow_redirects():
ret = requests.get('http://127.0.0.1:8000/test/', allow_redirects=False)
print(ret.text)
<br>
# 代理 出口IP 不是本機(jī)IP。 流程是:先給代理發(fā),代理幫助我們向目的地址發(fā)。
def param_proxies():
# proxies = {
# "http": "61.172.249.96:80",
# "https": "http://61.185.219.126:3128",
# }
# proxies = {'http://10.20.1.128': 'http://10.10.1.10:5323'}
# ret = requests.get("http://www.proxy#/123456", proxies=proxies)
# print(ret.headers)
# from requests.auth import HTTPProxyAuth
#
# proxyDict = {
# 'http': '77.75.105.165',
# 'https': '77.75.105.165'
# }
# auth = HTTPProxyAuth('username', 'mypassword')
#
# r = requests.get("http://www.google.com", proxies=proxyDict, auth=auth)
# print(r.text)
pass
<br>
# 流形式 比如下片
def param_stream():
ret = requests.get('http://127.0.0.1:8000/test/', stream=True)
print(ret.content)
ret.close()
# from contextlib import closing
# with closing(requests.get('http://httpbin.org/get', stream=True)) as r:
# # 在此處理響應(yīng)。迭代處理
# for i in r.iter_content():
# print(i)
def requests_session():
import requests
session = requests.Session()
### 1、首先登陸任何頁(yè)面,獲取cookie
i1 = session.get(url="http://dig.chouti.com/help/service")
### 2、用戶(hù)登陸,攜帶上一次的cookie,后臺(tái)對(duì)cookie中的 gpsd 進(jìn)行授權(quán)
i2 = session.post(
url="http://dig.chouti.com/login",
data={
'phone': "8612345678977",
'password': "xxxxxx",
'oneMonth': ""
}
)
i3 = session.post(
url="http://dig.chouti.com/link/vote?linksId=8589623",
)
print(i3.text)
http 與 https 區(qū)別
- http
本質(zhì)上就是 socket,http 請(qǐng)求不安全,因?yàn)闆](méi)有任何的加密措施。
- https
擁有加密措施,ssh 加密,有證書(shū)一說(shuō),服務(wù)器給請(qǐng)求的客戶(hù)端頒發(fā)證書(shū),客戶(hù)端使用證書(shū)對(duì)客戶(hù)端發(fā)送的數(shù)據(jù)加密成密文,然后發(fā)送給服務(wù)器,服務(wù)器通過(guò)證書(shū)進(jìn)行解密,檢測(cè)是否是匹配的,進(jìn)行傳輸信息。通信間必須使用證書(shū)。cert參數(shù)是證書(shū),主動(dòng)提供證書(shū),可以自己制作(缺錢(qián)的話),比如證書(shū)是“fuck.pem”,cert=('fuck.pem'),必須使用證書(shū),如果沒(méi)有證書(shū)則不能進(jìn)行通信。還有一類(lèi)證書(shū)需要自己買(mǎi)的第三方可信賴(lài)的證書(shū),系統(tǒng)在創(chuàng)建(一裝機(jī))的時(shí)候直接植入證書(shū),廠商幫忙做驗(yàn)證,這就是有錢(qián)和沒(méi)錢(qián)的區(qū)別,用戶(hù)不需要自己在瀏覽器上安裝證書(shū)了,pem是證書(shū)的格式,cert=('fuck.crt','xxx.key'),和自己辦法的沒(méi)區(qū)別,需要啥樣給啥樣,完成的事都是做加密使用。還有一個(gè)參數(shù)叫 verify,如果 verify=False,則表示忽略證書(shū),直接發(fā)請(qǐng)求直接拿結(jié)果,一般網(wǎng)站是允許用的,但是服務(wù)器必須要證書(shū)也白搭。
以上就是python request 模塊詳細(xì)介紹的詳細(xì)內(nèi)容,更多關(guān)于python request 模塊的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!
- 淺析Python requests 模塊
- Python使用requests模塊爬取百度翻譯
- Python grequests模塊使用場(chǎng)景及代碼實(shí)例
- Python requests模塊安裝及使用教程圖解
- Python requests模塊cookie實(shí)例解析
- python爬蟲(chóng)開(kāi)發(fā)之Request模塊從安裝到詳細(xì)使用方法與實(shí)例全解
- Python3離線安裝Requests模塊問(wèn)題
- python爬蟲(chóng) 基于requests模塊的get請(qǐng)求實(shí)現(xiàn)詳解
- python爬蟲(chóng) 基于requests模塊發(fā)起ajax的get請(qǐng)求實(shí)現(xiàn)解析
- python利用re,bs4,requests模塊獲取股票數(shù)據(jù)
- Python實(shí)現(xiàn)使用request模塊下載圖片demo示例
- Python3使用requests模塊實(shí)現(xiàn)顯示下載進(jìn)度的方法詳解
相關(guān)文章
python支持同時(shí)存在多個(gè)版本的操作步驟
這篇文章主要介紹了python支持同時(shí)存在多個(gè)版本的操作步驟,在已有Python 3.8的情況下,安裝新的Python 3.9版本,感興趣的小伙伴可以參考文中步驟,文章中介紹的非常詳細(xì),需要的朋友可以參考下2024-03-03
Python遞歸求出列表(包括列表中的子列表)的最大值實(shí)例
今天小編就為大家分享一篇Python遞歸求出列表(包括列表中的子列表)的最大值實(shí)例,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2020-02-02
django中的自定義分頁(yè)器的實(shí)現(xiàn)示例
本文主要介紹了django中的自定義分頁(yè)器的實(shí)現(xiàn)示例,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2022-08-08
Python中斷言Assertion的一些改進(jìn)方案
python中的斷言Assertion使用起來(lái)很方便,但是也不盡如人意的地方,所以這篇文章通過(guò)幾個(gè)方面對(duì)Python中的斷言進(jìn)行了改進(jìn),感興趣的朋友們可以參考借鑒,下面來(lái)一起看看吧。2016-10-10
Python json模塊與jsonpath模塊區(qū)別詳解
這篇文章主要介紹了Python json模塊與jsonpath模塊區(qū)別詳解,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-03-03
Python如何實(shí)現(xiàn)后端自定義認(rèn)證并實(shí)現(xiàn)多條件登陸
這篇文章主要介紹了Python如何實(shí)現(xiàn)后端自定義認(rèn)證并實(shí)現(xiàn)多條件登陸,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-06-06
Python Sweetviz輕松實(shí)現(xiàn)探索性數(shù)據(jù)分析
Sweetviz是一個(gè)開(kāi)放源代碼Python庫(kù),可生成精美的高密度可視化文件,以單行代碼啟動(dòng)EDA(探索性數(shù)據(jù)分析)。輸出是一個(gè)完全獨(dú)立的HTML應(yīng)用程序,該系統(tǒng)圍繞快速可視化目標(biāo)值和比較數(shù)據(jù)集而構(gòu)建。其目標(biāo)是幫助快速分析目標(biāo)特征,訓(xùn)練與測(cè)試數(shù)據(jù)以及其他此類(lèi)數(shù)據(jù)表征任務(wù)2021-11-11
利用python讀取YUV文件 轉(zhuǎn)RGB 8bit/10bit通用
今天小編就為大家分享一篇利用python讀取YUV文件 轉(zhuǎn)RGB 8bit/10bit通用,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2019-12-12

