#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?