Редактирование заголовков файлов wav для использования с QSound / pyqt5 из python (Watson Text To Speech TTS)

#python #pyqt5 #wav #watson-text-to-speech

#python #pyqt5 #wav #watson-преобразование текста в речь

Вопрос:

QSound из pyqt5 доставляет мне проблемы, некоторые файлы wav работают хорошо. Другие вызывают ошибку приложения Qt и не запускаются. Я с помощью исследований сузил круг подозреваемых до заголовков файлов wav.

Если я открою файл wav в Audacity и экспортирую его как файл wav… экспортированный файл wav работает отлично. Однако мне нужно решение, которое запускается из моего скрипта python.

Я получаю свои файлы wav из API преобразования текста в речь Watson, не уверен, могу ли я контролировать, какие заголовки он включает.

 import sys
from PyQt5.QtWidgets import QApplication, QLabel, QMainWindow
from PyQt5.QtCore import Qt
from PyQt5.QtMultimedia import QSound

from ibm_watson import TextToSpeechV1
from ibm_cloud_sdk_core.authenticators import IAMAuthenticator


def list_to_speech(text, language='ja-JP_EmiV3Voice'):
    api_key = "my_api_key"
    url = "url"

    # Set up service
    authenticator = IAMAuthenticator(api_key)
    # Now TTS service
    tts = TextToSpeechV1(authenticator=authenticator)
    # Set Service URL
    tts.set_service_url(url)
    with open('text_to_speech.wav', 'wb') as audio_file:
        res = tts.synthesize(text, accept='audio/wav', voice=language).get_result()
        audio_file.write(res.content)


class MainWindow(QMainWindow):
    def __init__(self, *args, **kwargs):
        super(MainWindow, self).__init__(*args, **kwargs)
        self.sound = QSound("text_to_speech.wav")
        self.sound.play()

        label = QLabel("This PyQt5 window will (try to) play the wav file!")
        label.setAlignment(Qt.AlignCenter)

        self.setCentralWidget(label)


if __name__ == "__main__":
    # the file saved by list_to_speech won't play as QSound(text_to_speech.wav).play()
    # (instead it crashes the app before opening)
    # 
    # if I open the text_to_speech.wav file in Audacity and export it with empty headers,
    # then comment out next line, it works.
    list_to_speech("ありがとう")
    app = QApplication(sys.argv)
    window = MainWindow()
    window.show()
    app.exec_()
 

Ответ №1:

Возможное решение — использовать не QSound, а QMediaPlayer, который позволяет обрабатывать другие кодеки:

 import os
import sys

from PyQt5.QtWidgets import QApplication, QLabel, QMainWindow
from PyQt5.QtCore import Qt, QUrl
from PyQt5.QtMultimedia import QMediaPlayer, QMediaContent

CURRENT_DIR = os.path.dirname(os.path.realpath(__file__))

# ...

class MainWindow(QMainWindow):
    def __init__(self, *args, **kwargs):
        super(MainWindow, self).__init__(*args, **kwargs)

        filename = os.path.join(CURRENT_DIR, "text_to_speech.wav")

        self.player = QMediaPlayer()
        url = QUrl.fromLocalFile(filename)
        self.player.setMedia(QMediaContent(url))
        self.player.play()

        label = QLabel("This PyQt5 window will (try to) play the wav file!")
        label.setAlignment(Qt.AlignCenter)

        self.setCentralWidget(label)

# ...
 

Примечание: Другой вариант — использовать другой формат, например mp3.

Комментарии:

1. Нерабочее решение. — Загружается файл wav — Теперь откроется приложение Qt (это новое.) Однако, когда запускается self.player.play(), звук не проходит через мои динамики.

2. @JohnDeBaggis Какая у вас операционная система? Qt Multimedia использует сторонние библиотеки для кодеков, установлены ли у вас кодеки? Я протестировал ваше приложение с помощью предоставленных вами URL и apikey, и оно работало не с QSound, а с QMediaPlayer (теперь оно больше не может тестироваться, поскольку вы деактивировали ключ api)

3. Я нахожусь в системе windows10, у меня, вероятно, не установлено много дополнительных кодеков.

4. @JohnDeBaggis я только что протестировал его, и он работает в Linux. Попробуйте установить кодеки k-lite: codecguide.com/download_kl.htm

5. @JohnDeBaggis Вы пробовали использовать другой формат, например mp3?