gpt4 book ai didi

python - 如何连接多个音频输出 channel 以与 PyAudio 一起使用?

转载 作者:太空宇宙 更新时间:2023-11-03 14:20:40 33 4
gpt4 key购买 nike

我是 PyAudio 和音频操作的新手,所以这是一个非常基本的问题,我还没有找到答案 - PyAudio 为您提供了通过 channel 映射将声音发送到不同 channel 的选项,但是您如何获得那些不同的 channel 连接到你的计算机/Python?

是否像配对蓝牙扬声器一样简单,从而将计算机的内部扬声器作为一个 channel ,将蓝牙扬声器作为第二个 channel ?

(最终我想同时播放 2 个 .wav 文件,但在 2 个不同的输出上分别播放。如果有比 PyAudio 更简单的方法,也请听听!)

感谢您的帮助! :)

最佳答案

我相信使用 sounddevice 可以实现这一点。请参阅链接了解安装详细信息。

sounddevice 提供了一种使用 sd.query_devices() 列出不同输入/输出音频设备的简单方法

>>> print sd.query_devices()
0 Microsoft Sound Mapper - Input, MME (2 in, 0 out)
> 1 Jack Mic (IDT High Definition A, MME (2 in, 0 out)
2 Microphone Array (IDT High Defi, MME (2 in, 0 out)
3 Microsoft Sound Mapper - Output, MME (0 in, 2 out)
< 4 Speakers / Headphones (IDT High, MME (0 in, 2 out)
5 Communication Headphones (IDT H, MME (0 in, 2 out)

此处设备 ID (4) 是输出设备(扬声器)。我没有配置蓝牙。但如果有,它应该显示在列表中。

列出两个输出设备后,您可以使用以下命令简单地重定向它们sd.play(data_array,sampling_Frequency,device=device_id_)

虽然 sounddevice 在播放过程中存在阻塞 IO 的限制,但我相信可以通过使用线程来克服它。

注意:以下代码未在两个不同的设备上进行测试。让我知道它是否有效。

import sounddevice as sd
import soundfile as sf
import threading
from threading import Thread

def audioFunc1():
audio1 = "audio1.wav"
data1, fs1 = sf.read(audio1, dtype='float32')
sd.play(data1, fs1, device=3) #speakers

def audioFunc2():
audio2 = "audio2.wav"
data2, fs2 = sf.read(audio2, dtype='float32')
sd.play(data2, fs2, device=10) #headset

if __name__ == '__main__':
Thread(target = audioFunc1).start()
Thread(target = audioFunc2).start()

关于python - 如何连接多个音频输出 channel 以与 PyAudio 一起使用?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/47969883/

33 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com