> 백엔드 개발 > 파이썬 튜토리얼 > FastAPI에 데이터를 게시한 후 파일을 다운로드하는 방법은 무엇입니까?

FastAPI에 데이터를 게시한 후 파일을 다운로드하는 방법은 무엇입니까?

Linda Hamilton
풀어 주다: 2024-10-31 11:03:01
원래의
505명이 탐색했습니다.

How to Download a File After POSTing Data in FastAPI?

FastAPI를 사용하여 데이터를 게시한 후 파일을 다운로드하는 방법

문제

텍스트 입력을 처리하고 이를 텍스트로 변환하는 웹 앱을 만들고 있습니다. 음성을 전달하고 다운로드할 오디오 파일을 반환합니다. HTML 페이지에 다운로드 옵션이 필요한데 제대로 구현할 수 없습니다.

Flask에서는 send_file 함수를 사용하여 유사한 설정을 구현할 수 있습니다. FastAPI를 사용하여 이 기능을 어떻게 복제합니까?

FastAPI 코드 및 HTML 예제

<code class="python">from fastapi import FastAPI, File, Form, UploadFile
from fastapi.responses import FileResponse, HTMLResponse
from fastapi.templating import Jinja2Templates
from gtts import gTTS

templates = Jinja2Templates(directory="templates")

def text_to_speech(language: str, text: str) -> str:
    tts = gTTS(text=text, lang=language, slow=False)
    tts.save("./temp/welcome.mp3")
    return "Text to speech conversion successful"

@app.get("/")
def home(request: Request):
    return templates.TemplateResponse("index.html", {"request": request})

@app.post("/text2speech")
async def home(request: Request):
    if request.method == "POST":
        form = await request.form()
        if form["message"] and form["language"]:
            language = form["language"]
            text = form["message"]
            translate = text_to_speech(language, text)
            path = "./temp/welcome.mp3"
            value = FileResponse("./temp/welcome.mp3", media_type="audio/mp3")
            return value</code>
로그인 후 복사
<code class="html"><!doctype html>
<title>Download MP3 File</title>
<h2>Download a file</h2>
<p><a href="{{ url_for('text2speech') }}">Download</a></p></code>
로그인 후 복사

솔루션

옵션 1: 필수 매개변수를 보장하기 위한 양식 키워드입니다. wait request.form()을 사용하고 필수 매개변수를 수동으로 확인하는 대신 Form(...)을 사용하여 매개변수를 필수로 만드세요. 수신된 데이터를 처리한 후 FileResponse를 사용하여 파일을 반환하고 Content-Disposition 헤더를 'attachment'로 설정합니다.

옵션 2: @app.api_route("/text2speech",method=["GET", "우편"]). 또는 @app.get("/text2speech") 및 @app.post("/text2speech")를 사용하여 별도의 엔드포인트를 정의할 수 있습니다.

또한 선택적으로 Fetch API를 사용하여 JavaScript 인터페이스를 설정하여 프런트엔드에서 파일을 다운로드할 수 있습니다.

참고:

  • 메모리에 맞지 않는 대용량 파일을 반환하려면 StreamingResponse를 사용하여 파일을 청크로 처리하세요.
  • 파일을 다운로드한 후 제거하려면 응답을 반환한 후 실행할 BackgroundTask를 생성하세요.

위 내용은 FastAPI에 데이터를 게시한 후 파일을 다운로드하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
저자별 최신 기사
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿