텍스트 입력을 처리하고 이를 텍스트로 변환하는 웹 앱을 만들고 있습니다. 음성을 전달하고 다운로드할 오디오 파일을 반환합니다. HTML 페이지에 다운로드 옵션이 필요한데 제대로 구현할 수 없습니다.
Flask에서는 send_file 함수를 사용하여 유사한 설정을 구현할 수 있습니다. FastAPI를 사용하여 이 기능을 어떻게 복제합니까?
<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 인터페이스를 설정하여 프런트엔드에서 파일을 다운로드할 수 있습니다.
참고:
위 내용은 FastAPI에 데이터를 게시한 후 파일을 다운로드하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!