GV-a / audio_processing.py
TDN-M's picture
Update audio_processing.py
9615271 verified
raw
history blame
801 Bytes
# audio_processing.py
import asyncio
import os
import tempfile
import edge_tts
# Lấy API key từ biến môi trường
EDGE_TTS_API_KEY = os.environ.get("EDGE_TTS_API_KEY", None) # Không cần API key cho edge-tts
def text_to_speech(text, voice, language):
"""
Chuyển đổi văn bản thành giọng nói bằng edge-tts.
"""
output_file = tempfile.NamedTemporaryFile(delete=False, suffix=".mp3")
tts = edge_tts.Communicate(text, voice)
tts.save(output_file.name).get()
return output_file.name
async def async_text_to_speech(text, voice, language):
"""
Chuyển đổi văn bản thành giọng nói (bất đồng bộ).
"""
loop = asyncio.get_event_loop()
return await loop.run_in_executor(None, text_to_speech, text, voice, language)