播放音频到输入设备 python

问题描述

我正在尝试制作一个程序,该程序使用 gtts 和 sounddevice 将书面文本播放到某个麦克风输入。所以这是我尝试过的方法

def speak(text,lang="en"):
    tts = gTTS(text=text,lang=lang)
    fp = BytesIO()
    tts.write_to_fp(fp)
    fp.seek(0)
    sd.play(speek,device=39)

当我用任何文本运行上面的代码时,我收到以下错误

Traceback (most recent call last):
  File "C:\Users\username\PycharmProjects\tts\tts.py",line 25,in <module>
    speak("hallo",lang="de")
  File "C:\Users\username\PycharmProjects\tts\tts.py",line 20,in speak
    sd.play(speek,device=39)
  File "C:\Users\username\AppData\Local\Programs\Python\python39\lib\site-packages\sounddevice.py",line 166,in play
    ctx.frames = ctx.check_data(data,mapping,kwargs.get('device'))
  File "C:\Users\username\AppData\Local\Programs\Python\python39\lib\site-packages\sounddevice.py",line 2468,in check_data
    frames,channels = data.shape
ValueError: too many values to unpack (expected 2)

所以我知道 data.shape 的值不止这 2 个,但这是在 sounddevice 中,所以要么是错误,要么是我做错了什么。任何想法为什么它不起作用?

解决方法

暂无找到可以解决该程序问题的有效方法,小编努力寻找整理中!

如果你已经找到好的解决方法,欢迎将解决方案带上本链接一起发送给小编。

小编邮箱:dio#foxmail.com (将#修改为@)

相关问答

Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其...
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。...
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbc...