Python實現不寫硬盤上傳文件
引言
你寫瞭一個 api,接受 client 上傳的文件,然後在上傳到 oss,你會怎麼做?先寫硬盤,然後在上傳到 oss?太笨瞭!
你寫瞭一個截圖服務,截到的圖要上傳到 oss,你會怎麼做?先寫硬盤,在上傳到 oss?太笨瞭!
這篇文章教你重新做人!
文本類型
使用 io.StringIO
import io from loguru import logger file_like_obj = io.StringIO("hahaha") logger.debug(file_like_obj) logger.debug(type(file_like_obj)) logger.debug(getattr(file_like_obj,'read')) logger.debug(file_like_obj.read())
輸出結果如下:
2022-07-11 21:23:51.206 | DEBUG | __main__:<module>:8 – <_io.StringIO object at 0x100323eb0>
2022-07-11 21:23:51.206 | DEBUG | __main__:<module>:9 – <class '_io.StringIO'>
2022-07-11 21:23:51.206 | DEBUG | __main__:<module>:10 – <built-in method read of _io.StringIO object at 0x100323eb0>
2022-07-11 21:23:51.206 | DEBUG | __main__:<module>:11 – hahaha
再看一個熟悉的:
import io from loguru import logger file_like_obj = io.StringIO("hahaha") with file_like_obj as f: logger.debug(f.read())
輸出結果如下:
2022-07-11 21:35:04.620 | DEBUG | __main__:<module>:9 – hahaha
二進制類型
使用 io.BytesIO
使用 requests 把字符串按照文件上傳
下面的代碼是標準的上傳文件的代碼:
import requests import io response = requests.post('http://localhost:5000/', files={ 'file': open('縱觀人類文明史.txt', 'r', encoding='utf-8') }) print(response.text)
但是我想把 open('縱觀人類文明史.txt', 'r', encoding='utf-8')
替換為字符串。為此我想到的辦法是把字符串先寫到硬盤上,在按照上面的代碼上傳,可是這太低效率(硬盤太低效率),平白無故多瞭兩次硬盤讀寫操作,我想直接把內存中的字符串按照文件上傳有什麼辦法嗎?
參考文檔
https://docs.python.org/zh-cn/3/library/io.html#io.StringIO
以上就是Python實現不寫硬盤上傳文件的詳細內容,更多關於Python不寫硬盤上傳文件的資料請關註WalkonNet其它相關文章!
推薦閱讀:
- python自動化測試通過日志3分鐘定位bug
- Python調用系統命令os.system()和os.popen()的實現
- Python爬蟲Requests庫的使用詳情
- Python基礎之模塊詳解
- Python異常類型以及處理方法匯總