我最近在运行Windows 10的新PC上安装了librosa(已经在另一台PC上使用了一段时间的软件包)。之后,我下载了ffmpeg的最新静态版本,并将其复制到C:
并将其添加到路径中。经过测试的ffmpeg,它就像一个魅力!对于python,我使用的是Anaconda环境,启动Jupyter Notebook并运行librosa.load(path, sr = None)
后,我已经
<ipython-input-3-1e009e0ae576> in <module>
----> 1 audio = librosa.load(pathToJson)
~\anaconda3\envs\tf_gpu\lib\site-packages\librosa\core\audio.py in load(path, sr, mono, offset, duration, dtype, res_type)
117
118 y = []
--> 119 with audioread.audio_open(os.path.realpath(path)) as input_file:
120 sr_native = input_file.samplerate
121 n_channels = input_file.channels
~\anaconda3\envs\tf_gpu\lib\site-packages\audioread\__init__.py in audio_open(path, backends)
114
115 # All backends failed!
--> 116 raise NoBackendError()
NoBackendError:
是不是很奇怪?然后,我遍历整个Internet,做了什么都不尝试修复它,然后我有了一个想法,可以在anaconda命令界面中运行我的代码行,它的工作原理是?这怎么可能?这是相同的环境。
python
Python 3.7.7 (default, Mar 23 2020, 23:19:08) [MSC v.1916 64 bit (AMD64)] :: Anaconda, Inc. on win32
Type "help", "copyright", "credits" or "license" for more information.
>>> import librosa
>>> librosa.load('test.wav')
(array([-0.00027 , -0.00039953, -0.0003659 , ..., -0.16393574,
-0.17814247, 0. ], dtype=float32), 22050)
我做了很多测试,我真的很喜欢我的Jupyter,所以任何帮助将不胜感激。我尝试了以下操作:我已经在用户和系统变量的路径中添加了C:\ffmpeg\bin
和C:\ffmpeg
。之后,我为ffmpeg和ffmpeg_bin分别为用户和系统变量创建了特定的变量。没有运气。之后,我尝试使用conda安装ffmpeg,但未成功。我测试的最后一件事是:
import audioread
audioread.ffdec.FFmpegAudioFile('test.wav')
,并且有效。谢谢
答案 0 :(得分:1)
您具有以下代码行:
audio = librosa.load(pathToJson)
在我看来,您不小心尝试使用librosa加载JSON文件。检查:D