CnJaFlashC-1 / app.py
OzoneAsai's picture
Update app.py
671ed40 verified
raw
history blame
3.3 kB
from flask import Flask, render_template, request, jsonify, url_for
from gtts import gTTS
import os
import logging
from translation_data import translation_dict_A, translation_dict_B, translation_dict_C, translation_dict_D, translation_dict_F, translation_dict_G
# Flask アプリケーションの初期化
app = Flask(__name__)
# ログの設定
logging.basicConfig(level=logging.DEBUG)
# 音声ファイルの保存ディレクトリ
AUDIO_DIR = 'static/audio'
# フラッシュカードのデータを管理
flashcards = {
'A': {
'english_sentences': list(translation_dict_A.keys()),
'japanese_translations': list(translation_dict_A.values())
},
'B': {
'english_sentences': list(translation_dict_B.keys()),
'japanese_translations': list(translation_dict_B.values())
},
'C': {
'english_sentences': list(translation_dict_C.keys()),
'japanese_translations': list(translation_dict_C.values())
},
'D': {
'english_sentences': list(translation_dict_D.keys()),
'japanese_translations': list(translation_dict_D.values())
},
'F': {
'english_sentences': list(translation_dict_F.keys()),
'japanese_translations': list(translation_dict_F.values())
},
'G': {
'english_sentences': list(translation_dict_G.keys()),
'japanese_translations': list(translation_dict_G.values())
}
}
# ヘルパー関数: 音声ファイルを生成
def generate_audio(text, set_name, index):
"""テキストに基づいて音声ファイルを生成する関数"""
filename = f"{AUDIO_DIR}/{set_name}_{index}.mp3"
# もしファイルが存在しない場合、生成
if not os.path.exists(filename):
logging.info(f"音声ファイルを生成中: {filename}")
tts = gTTS(text=text, lang='en')
tts.save(filename)
else:
logging.info(f"既存の音声ファイルを使用: {filename}")
return filename
# フラッシュカードの内容を JSON で返すエンドポイント
@app.route('/flashcards')
def index():
set_name = request.args.get('set', 'A')
index = int(request.args.get('index', 0))
if set_name in flashcards:
english_sentences = flashcards[set_name]['english_sentences']
japanese_translations = flashcards[set_name]['japanese_translations']
if 0 <= index < len(english_sentences):
english = english_sentences[index]
japanese = japanese_translations[index]
total = len(english_sentences)
# 音声ファイルの生成
audio_url = url_for('static', filename=f"audio/{set_name}_{index}.mp3")
generate_audio(english, set_name, index)
# フラッシュカードの情報を JSON で返す
return jsonify({
'set_name': set_name,
'index': index,
'total': total,
'english': english,
'japanese': japanese,
'audio_url': audio_url
})
else:
return jsonify({'error': 'Index out of range'}), 404
else:
return jsonify({'error': 'Set not found'}), 404
if __name__ == '__main__':
app.run(debug=True, host="0.0.0.0", port=7860)