Текст в речь Python 3.7 воспроизводит только один аудиофайл, иногда без звука, используя редактор IDLE - PullRequest
0 голосов
/ 05 марта 2019

Я использую редактор IDLE и Python 3.7, и я хотел бы знать, почему мой код не воспроизводит несколько аудиофайлов (последовательно), а иногда вообще не воспроизводит звук:

import re
import wave
import pyaudio
import _thread
import time

class TextToSpeech:

    CHUNK = 1024

    def __init__(self, words_pron_dict:str = 'cmudict-0.7b.txt'):
        self._l = {}
        self._load_words(words_pron_dict)

    def _load_words(self, words_pron_dict:str):
        with open(words_pron_dict, 'r') as file:
            for line in file:
                if not line.startswith(';;;'):
                    key, val = line.split('  ',2)
                    self._l[key] = re.findall(r"[A-Z]+",val)

    def get_pronunciation(self, str_input):
        list_pron = []
        for word in re.findall(r"[\w']+",str_input.upper()):
            if word in self._l:
                list_pron += self._l[word]
        print(list_pron)
        delay=0
        for pron in list_pron:
            _thread.start_new_thread( TextToSpeech._play_audio, (pron,delay,))
            delay += 0.145


def _play_audio(sound, delay):
    try:
        time.sleep(delay)
        wf = wave.open("sounds/"+sound+".wav", 'rb')
        p = pyaudio.PyAudio()
        stream = p.open(format=p.get_format_from_width(wf.getsampwidth()),
                        channels=wf.getnchannels(),
                        rate=wf.getframerate(),
                        output=True)

        data = wf.readframes(TextToSpeech.CHUNK)

        while data:
            stream.write(data)
            data = wf.readframes(TextToSpeech.CHUNK)

        stream.stop_stream()
        stream.close()

        p.terminate()
        return
    except:
        pass

if __name__ == '__main__':
    tts = TextToSpeech()
    while True:
        tts.get_pronunciation(input('Enter a word or phrase: '))

У меня естьсписок аудиофайлов, которые будут воспроизводиться в определенном порядке, в зависимости от того, какое слово я ввожу при запуске кода.В коде нет ошибок, но когда я запускаю его, когда я набираю слово, он воспроизводит только первый необходимый аудиофайл (Пример: когда я набираю слово «buy», ему требуются два звука: «b» и «ie»).воспроизводится вместе), но он воспроизводит только первый звук, "b", а иногда вообще не воспроизводит звук.

Почему он не воспроизводит несколько аудиофайлов?Я знаю, что многие люди сталкивались с этой проблемой, но не смогли ее решить.Заранее благодарю за помощь, очень признателен:)

...