mikuTTSAPI / app.py
soiz's picture
Update app.py
05c9eab verified
from flask import Flask, request, jsonify, send_file
from rvc import * # 既存のTTSモデルがこのモジュールにあると仮定します
import os
app = Flask(__name__)
# モデルの初期化 (必要ならば)
# Gradio用に定義されていたモデルやパラメータをここで適用
models = [...] # 実際のモデルのリスト
tts_voices = [...] # TTS声のリスト
@app.route('/tts', methods=['GET'])
def tts_api():
try:
# URLパラメータの取得
model_name = request.args.get('model_name', default=models[0], type=str)
f0_key_up = request.args.get('f0_key_up', default=6, type=int)
f0_method = request.args.get('f0_method', default="rmvpe", type=str)
index_rate = request.args.get('index_rate', default=1.0, type=float)
protect0 = request.args.get('protect0', default=0.33, type=float)
tts_voice = request.args.get('tts_voice', default="ja-JP-NanamiNeural-Female", type=str)
speed = request.args.get('speed', default=0, type=int)
tts_text = request.args.get('tts_text', default="こんにちは、私の名前は初音ミクです!", type=str)
# Gradioと同じTTS関数を呼び出して、音声を生成
info_text, edge_tts_output, tts_output = tts(
model_name, speed, tts_text, tts_voice, f0_key_up, f0_method, index_rate, protect0
)
# 処理後のtts_outputがタプルで返される場合、そのパスを取得
if isinstance(tts_output, tuple):
tts_output = tts_output[0] # タプルの最初の要素を取得
# 生成されたTTSファイルをクライアントに返す(tts_outputを使用)
if tts_output and os.path.exists(tts_output):
return send_file(tts_output, as_attachment=True)
# エッジTTS出力を返さないようにする(これは不要)
# if edge_tts_output and os.path.exists(edge_tts_output):
# return send_file(edge_tts_output, as_attachment=True)
return jsonify({"error": "Failed to generate TTS output"}), 500
except Exception as e:
# エラーが発生した場合はJSONでエラーを返す
return jsonify({"error": str(e)}), 400
if __name__ == '__main__':
app.run(host='0.0.0.0', port=7860)