您好,登錄后才能下訂單哦!
這篇文章主要講解了Python基于requests實現模擬上傳文件的方法,內容清晰明了,對此有興趣的小伙伴可以學習一下,相信大家閱讀完之后會有幫助。
方法1:
1.安裝requests_toolbelt依賴庫
#代碼實現 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:\\Users\\Acer\\Pictures\\Screenshots\\1.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對象需要的參數:將tempPassword_data的字段合并至files
1.files參數介紹:
1.字典key對應file字段(我們系統是這樣,具體結合前端實際的字段為準),如圖
2.字典value里面的對象:
1.filename(服務器最終存儲的文件名)
2.filepath(具體的文件路徑,注意轉義),文件是以二進制的形式進行傳輸的,所以這里傳輸時以二進制的形式打開文件并傳輸
3.content_type:具體結合前端實際的字段為準:一般可定義為: 文本(text)/圖片(image)等[/code][code]
3.tempPassword_data:為文件上傳時的附帶參數
strToDict方法:自己手寫的一個字符串轉dict的方法
遇到的問題:
這個錯誤是說,int對象不能被編碼,所以需要手動將int對象轉換為str,所以我在此方法中定義了value_type這個參數,用于將字典中的所有value轉換為str類型
#具體代碼實現,僅供參考 def strToDict(str_in,value_type=None): # value_type:轉換字典的value為指定的類型,未防止異常,目前僅支持str # '''將str轉換為dict輸出''' # '''將帶有time關鍵字的參數放到字符串末尾''' # 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復制出來的參數''' 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第一位為字母數據獲取[]_ str_sign = re.search('[^a-zA-Z0-9\_\[\]+]', str_in_key[0]) if str_sign is None: # 處理value中的空格與轉義符 str_in_value = i[colon_str_index + 1:].strip() str_in_value=str_in_value.replace('\\','') try: # 遇到是object類型的數據轉換一下 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("參數都沒有,還處理個球嘛") return None
3.請求時將headers的content設置為m.content_type,會設置headers的content_type為form—data,類型為str:
MultipartEncoder相關源碼:
4.請求時設置data為m,會輸出一個MultipartEncoder對象:
方法2:
直接使用requests,無需依賴requests_toolbelt庫
過程大同小異,也是需要將字典的value轉換為str
注意:headers不要傳content_type字段,headers不要傳content_type字段,headers不要傳content_type字段
請求時:data對應附加參數,files對應files對象
#相關代碼 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:\\Users\\Acer\\Pictures\\Screenshots\\1.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())
看完上述內容,是不是對Python基于requests實現模擬上傳文件的方法有進一步的了解,如果還想學習更多內容,歡迎關注億速云行業資訊頻道。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。