我无法在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。
谢谢。
答案 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)