Python基于requests實現(xiàn)模擬上傳文件
方法1:
1.安裝requests_toolbelt依賴庫
#代碼實現(xiàn)def upload(self): login_token = self.token.loadTokenList() for token in login_token: tempPassword_url = self.config[’crm_test_api’]+’/document/upload’ tempPassword_data = self.data_to_str.strToDict(’’’title:1.png course_name_id:63 course_id:1112 desc:7 doc_type:1 is_public:1’’’,value_type=’str’) files={’file’: (’1.png’, open(’C:UsersAcerPicturesScreenshots1.png’, ’rb’), ’image/png’)} tempPassword_data.update(files) m = MultipartEncoder(fields=tempPassword_data ) tempPassword_headers = {'Content-Type': m.content_type, 'token': token} tempPassword_request = requests.post(url=tempPassword_url,data=m,headers=tempPassword_headers) print(tempPassword_request.content)
2.組裝MultipartEncoder對象需要的參數(shù):將tempPassword_data的字段合并至files
1.files參數(shù)介紹:
1.字典key對應(yīng)file字段(我們系統(tǒng)是這樣,具體結(jié)合前端實際的字段為準(zhǔn)),如圖
2.字典value里面的對象:
1.filename(服務(wù)器最終存儲的文件名)
2.filepath(具體的文件路徑,注意轉(zhuǎn)義),文件是以二進(jìn)制的形式進(jìn)行傳輸?shù)模赃@里傳輸時以二進(jìn)制的形式打開文件并傳輸
3.content_type:具體結(jié)合前端實際的字段為準(zhǔn):一般可定義為: 文本(text)/圖片(image)等[/code][code]
3.tempPassword_data:為文件上傳時的附帶參數(shù)
strToDict方法:自己手寫的一個字符串轉(zhuǎn)dict的方法
遇到的問題:
這個錯誤是說,int對象不能被編碼,所以需要手動將int對象轉(zhuǎn)換為str,所以我在此方法中定義了value_type這個參數(shù),用于將字典中的所有value轉(zhuǎn)換為str類型
#具體代碼實現(xiàn),僅供參考def strToDict(str_in,value_type=None): # value_type:轉(zhuǎn)換字典的value為指定的類型,未防止異常,目前僅支持str # ’’’將str轉(zhuǎn)換為dict輸出’’’ # ’’’將帶有time關(guān)鍵字的參數(shù)放到字符串末尾’’’ # print(str_in) if str_in: match_str = ’:’ split_str = ’n’ split_list = str_in.split(split_str) str_in_dict = {} for i in split_list:colon_str_index = i.find(match_str)if colon_str_index == -1: # ’’’處理firefox復(fù)制出來的參數(shù)’’’ match_str = ’t’ or ’ ’ colon_str_index = i.find(match_str)# ’’’去掉key、value的空格,key中的引號’’’str_in_key = i[:colon_str_index].strip()str_in_key = str_in_key.replace(’'’,’’)str_in_key = str_in_key.replace('’',’’)# 正則過濾無用key,只保留key第一位為字母數(shù)據(jù)獲取[]_str_sign = re.search(’[^a-zA-Z0-9_[]+]’, str_in_key[0])if str_sign is None: # 處理value中的空格與轉(zhuǎn)義符 str_in_value = i[colon_str_index + 1:].strip() str_in_value=str_in_value.replace(’’,’’) try: # 遇到是object類型的數(shù)據(jù)轉(zhuǎn)換一下 str_in_value=eval(str_in_value) except BaseException as error: str_in_value=str_in_value if value_type in [’str’,’string’]: str_in_value=str(str_in_value) else: str_in_value=str_in_value str_in_dict[str_in_key] = str_in_value return str_in_dict else: print('參數(shù)都沒有,還處理個球嘛') return None
3.請求時將headers的content設(shè)置為m.content_type,會設(shè)置headers的content_type為form—data,類型為str:
MultipartEncoder相關(guān)源碼:
4.請求時設(shè)置data為m,會輸出一個MultipartEncoder對象:
方法2:
直接使用requests,無需依賴requests_toolbelt庫
過程大同小異,也是需要將字典的value轉(zhuǎn)換為str
注意:headers不要傳content_type字段,headers不要傳content_type字段,headers不要傳content_type字段
請求時:data對應(yīng)附加參數(shù),files對應(yīng)files對象
#相關(guān)代碼def upload(self): login_token = self.token.loadTokenList() for token in login_token: tempPassword_url = self.config[’crm_test_api’]+’/document/upload’ tempPassword_data = self.data_to_str.strToDict(’’’title:1.png course_name_id:63 course_id:1112 desc:7 doc_type:1 is_public:1’’’,value_type=’str’) files={’file’: (’1.png’, open(’C:UsersAcerPicturesScreenshots1.png’, ’rb’), ’image/png’)} tempPassword_headers = {'token': token} tempPassword_request = requests.post(url=tempPassword_url,data=tempPassword_data,files=files,headers=tempPassword_headers) print(tempPassword_request.json())
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持好吧啦網(wǎng)。
相關(guān)文章:
1. idea設(shè)置提示不區(qū)分大小寫的方法2. HTTP協(xié)議常用的請求頭和響應(yīng)頭響應(yīng)詳解說明(學(xué)習(xí))3. Django使用HTTP協(xié)議向服務(wù)器傳參方式小結(jié)4. CentOS郵件服務(wù)器搭建系列—— POP / IMAP 服務(wù)器的構(gòu)建( Dovecot )5. .NET SkiaSharp 生成二維碼驗證碼及指定區(qū)域截取方法實現(xiàn)6. docker容器調(diào)用yum報錯的解決辦法7. 原生JS實現(xiàn)記憶翻牌游戲8. css代碼優(yōu)化的12個技巧9. django創(chuàng)建css文件夾的具體方法10. ASP.NET MVC通過勾選checkbox更改select的內(nèi)容
