En este post de programación en Python te mostraré un ejemplo que hice hace algún tiempo. Se trata de una API que convierte el texto a voz y reproduce el sonido resultante en la computadora en donde está el script.
De este modo podemos ejecutar el script y consumirlo desde cualquier cliente para reproducir el texto convertido a voz. En otras palabras vamos a reproducir un sonido a partir del texto usando Python (TTS).
Esto podría agregarse al turnero web para que se reproduzca un sonido en voz alta en la computadora, saltando las limitaciones de JavaScript para reproducir sonidos sin interacción del usuario.
Explicación del programa
Vamos a crear una API usando Flask, leer la variable de la URL (para el texto que se va a convertir a audio) y reproducir el sonido usando pyttsx3.
Nota: te recomiendo ver esos posts que he citado, para que instales las dependencias necesarias.
API para texto a voz con Python
El programa final quedará muy simple. Es el siguiente:
"""
Reproducir sonido a partir de texto con Python
https://parzibyte.me/blog
"""
from flask import Flask, request
import pyttsx3
NUMBER_OF_TIMES_REPEAT_AUDIO = 2
app = Flask(__name__)
@app.route('/')
def play_sound():
text = request.args.get("text")
if not text:
return ""
else:
engine = pyttsx3.init()
engine.setProperty("rate", 150)
for _ in range(NUMBER_OF_TIMES_REPEAT_AUDIO):
engine.say(text)
engine.runAndWait()
return ""
if __name__ == "__main__":
app.run(host='0.0.0.0', port=8000, debug=True)
Exponemos una ruta, leemos la variable text
de la URL y lo reproducimos el número de veces que indique la constante NUMBER_OF_TIMES_REPEAT_AUDIO
. Para consumirla, simplemente debemos hacer una petición GET a la URL.
Por ejemplo, dado que en este caso la API escucha en el puerto 8000 podemos invocarla así:
http://localhost:8000/?text=Hola%20mundo
Y se reproducirá un sonido que dirá “Hola mundo”.