首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >无法使用声音设备录制声音

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

Stack Overflow用户
提问于 2018-12-11 13:26:26
回答 2查看 1.5K关注 0票数 3

我无法在python中使用sounddevice录制音频。这段代码以前可以在旧版本的Mac OS上运行。

python3代码如下:

代码语言:javascript
复制
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)

输出为

代码语言:javascript
复制
array([[0.],
       [0.],
       [0.],
       ...,
       [0.],
       [0.],
       [0.]], dtype=float32)

虽然不是所有的值都在这里显示,但我已经确认它们都是零。当声音记录正确时,这些值中的大多数都是非零值。

我已确认设备设置正确:

代码语言:javascript
复制
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。

谢谢。

EN

回答 2

Stack Overflow用户

发布于 2020-03-01 06:23:28

我也遇到了类似的问题,因为vscode的终端没有向操作系统申请使用麦克风的许可。当我在一个普通的终端上启动它并接受请求后,它在两个终端上都工作得很好。

希望我能帮上忙

票数 4
EN

Stack Overflow用户

发布于 2020-02-14 23:12:57

试试这段代码

代码语言:javascript
复制
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)
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/53717870

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档