无法使用声音设备录制声音

时间:2018-12-11 05:26:26

标签: python audio-recording python-sounddevice

我无法在Python中使用sounddevice录制音频。此代码以前在较旧版本的Mac OS上有效。

python3代码如下:

import sounddevice as sd
import numpy as np
fs = 48000
duration=5
rec = sd.rec(int(duration * fs), samplerate=fs, channels=1, blocking=True)
print(rec)

输出为

array([[0.],
       [0.],
       [0.],
       ...,
       [0.],
       [0.],
       [0.]], dtype=float32)

尽管此处未显示所有值,但我已经确认它们均为零。正确录制声音后,这些值大多数都不为零。

我已确认设备设置正确:

sd.default.device # Output is [2, 3]

python3 -m sounddevice
  0 DisplayPort, Core Audio (0 in, 2 out)
  1 DisplayPort, Core Audio (0 in, 2 out)
> 2 MacBook Pro Microphone, Core Audio (1 in, 0 out)
< 3 MacBook Pro Speakers, Core Audio (0 in, 2 out)

这与Mac OS中的权限有关吗?我正在使用Mojave。

谢谢。

2 个答案:

答案 0 :(得分:3)

我有一个类似的问题,因为vscode的终端没有要求操作系统允许使用麦克风。一旦我在常规终端上启动它并接受了请求,它在两个终端上都可以正常工作。

希望我能帮忙

答案 1 :(得分:1)

尝试此代码

import sounddevice as sd
from scipy.io.wavfile import write

fs=44100
duration=5
print("recording...............")


record_voice=sd.rec(int(duration * fs),samplerate=fs,channels=2)
sd.wait()       
write("sound.wav",fs,record_voice)