python使用form-data形式上傳文件請(qǐng)求的方法
雖然現(xiàn)在基本上都約定俗成的接口都用json形式請(qǐng)求
但是不可避免地 有些接口需要傳文件流,此時(shí)就需要用form-data形式上傳了
for.e:
存在以下接口,通過(guò)接口創(chuàng)建海報(bào)圖 但需要上傳縮略圖,
此時(shí)接口的Content-Type就不能是application/json,而是multipart/form-data;
參數(shù)格式也是以表單形式傳入
postman中設(shè)置文件流很簡(jiǎn)單 ,設(shè)置問(wèn)file格式,然后就可以在本地選擇文件上傳,見(jiàn)下圖
實(shí)際請(qǐng)求接口就可以成功
使用python完成上方請(qǐng)求 需要明確的請(qǐng)求方式及數(shù)據(jù)類型以及上傳文件 讀取文件
import requests import json from requests_toolbelt.multipart.encoder import MultipartEncoder url='http://XXX.xxx.xxx.xx:9900/api-marketing-center/poster/save' data={'activityName':'我是個(gè)海報(bào)2', 'backgroundPicUrl':'https://xxxxx/default/f865a1aa66adfe50d005bd840e2c3356.jpg', 'copywriting':'我是個(gè)海報(bào) 看看我2', 'endTime':'2021-08-14 16:00:00', 'startTime':'2021-08-11 16:00:00', 'giftPicUrl':'https://xxxxx/file/c363c3173ac7c02393bf60018031073d.PNG', 'qrCodeUrl':'https://xxxxxx/file/c363c3173ac7c02393bf60018031073d.PNG', 'posterUrlThumbnail':'文件' } files = {"posterUrlThumbnail": open('C:/Users/Lenovo/Desktop/格式測(cè)試/12.PNG', "rb")} headers={'AUTH_MERCHANTS_ID': '76', 'Authorization': 'Bearer ad8cbdf3-c827-470a-aba5-076f0f3a9628'} r=requests.post(url=url,params=data, headers=headers,files=files) print(r.json()) #{'code': 0, 'msg': '操作成功', 'data': None}
data:輸入請(qǐng)求的參數(shù),其中需要注意上傳文件流的參數(shù)名稱
files = {"posterUrlThumbnail": open('C:/Users/Lenovo/Desktop/格式測(cè)試/12.PNG', "rb")}
posterUrlThumbnail為參數(shù)名稱用于賦值,打開(kāi)文件,讀取賦值
上方使用最簡(jiǎn)單的寫死的headers,
調(diào)用requests庫(kù)的方法去請(qǐng)求
即可得到結(jié)果
當(dāng)然也可以復(fù)雜點(diǎn)封裝個(gè)登錄方法,去調(diào)用登錄,獲取token以及需要的頭部參數(shù)
總結(jié)
到此這篇關(guān)于python使用form-data形式上傳文件請(qǐng)求的文章就介紹到這了,更多相關(guān)python form-data上傳文件請(qǐng)求內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Python使用wxPython和PyMuPDF實(shí)現(xiàn)合并PDF文檔
處理大量的PDF文檔可能會(huì)變得復(fù)雜和耗時(shí),但是,使用Python編程和一些強(qiáng)大的庫(kù),可以使這個(gè)任務(wù)變得簡(jiǎn)單而高效,下面我們就來(lái)看看Python如何使用wxPython和PyMuPDF合并PDF文檔并自動(dòng)復(fù)制到剪貼板吧2023-11-11在Pandas中導(dǎo)入CSV數(shù)據(jù)時(shí)去除默認(rèn)索引的方法匯總
在Pandas中讀取CSV數(shù)據(jù)時(shí),會(huì)默認(rèn)將第一列設(shè)為索引列index,但有時(shí)候我們并不需要索引,或者希望指定自己的索引列,本文將介紹幾種在Pandas中導(dǎo)入CSV數(shù)據(jù)時(shí)去除默認(rèn)索引的方法,需要的朋友可以參考下2023-05-05使用PyOpenGL繪制三維坐標(biāo)系實(shí)例
今天小編就為大家分享一篇使用PyOpenGL繪制三維坐標(biāo)系實(shí)例,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2019-12-12