Bei Verwendung der Requests-Toolbelt-Bibliothek Achten Sie darauf, sowohl den Dateinamen als auch den Content-Type-Header anzugeben, wenn Sie das Feld für upload_file deklarieren. Hier ist ein Beispiel:
filename = 'my_file.txt' m = MultipartEncoder(fields={'upload_file': (filename, open(filename, 'rb'))}) r = requests.post( url, data=m, headers={'Content-Type': m.content_type}, verify=False, ) print(r.request.headers) # confirm that the 'Content-Type' header has been set.
Eine weitere Option ist die Verwendung von Python-Anfragen oder HTTPX-Bibliotheken, die beide Streaming-Datei-Uploads effizient verarbeiten können. Hier sind jeweils Beispiele:
Anfragen verwenden:
import requests url = '...' filename = '...' with open(filename, 'rb') as file: r = requests.post( url, files={'upload_file': file}, headers={'Content-Type': 'multipart/form-data'}, )
HTTPX verwenden:
import httpx url = '...' filename = '...' with open(filename, 'rb') as file: r = httpx.post( url, files={'upload_file': file}, )
HTTPX automatisch unterstützt Streaming-Datei-Uploads, während Anfragen erfordern, dass Sie den Content-Type-Header auf setzen 'multipart/form-data'.
Mit der .stream()-Methode von FastAPI können Sie das Laden einer großen Datei in den Speicher vermeiden, indem Sie als Stream auf den Anforderungstext zugreifen . Um diesen Ansatz zu verwenden, befolgen Sie diese Schritte:
Um sicherzustellen, dass die hochgeladene Dateigröße einen angegebenen Wert nicht überschreitet Wenn Sie die Grenze überschreiten, können Sie einen MaxSizeValidator verwenden. Hier ist ein Beispiel:
from streaming_form_data import streaming_form_data from streaming_form_data import MaxSizeValidator FILE_SIZE_LIMIT = 1024 * 1024 * 1024 # 1 GB def validate_file_size(chunk: bytes): if FILE_SIZE_LIMIT > 0: streaming_form_data.validators.MaxSizeValidator( FILE_SIZE_LIMIT). __call__(chunk)
Hier ist ein Beispielendpunkt, der diese Techniken beinhaltet:
from fastapi import FastAPI, File, Request from fastapi.responses import HTMLResponse from streaming_form_data.targets import FileTarget, ValueTarget from streaming_form_data import StreamingFormDataParser app = FastAPI() @app.post('/upload') async def upload(request: Request): # Parse the HTTP headers to retrieve the boundary string. parser = StreamingFormDataParser(headers=request.headers) # Register FileTarget and ValueTarget objects. file_ = FileTarget() data = ValueTarget() parser.register('upload_file', file_) parser.register('data', data) async for chunk in request.stream(): parser.data_received(chunk) # Validate file size (if necessary) validate_file_size(file_.content) # Process the uploaded file and data. return {'message': 'File uploaded successfully!'}
Das obige ist der detaillierte Inhalt vonWie lade ich große Dateien (≥3 GB) effizient auf ein FastAPI-Backend hoch?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!