报错与解决:UFuncTypeError: ufunc ‘add‘ did not contain a loop with signature matching types (dtype(‘<U21‘

本文介绍了一个关于音频处理中MFCC特征提取过程中遇到的错误及解决方案。作者在尝试从音乐文件中提取MFCC特征时遇到了类型匹配错误,并给出了通过类型转换解决该问题的方法。此外,还提供了完整的Python代码示例。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

报错

当笔者运行代码train_val.iloc[idx].name) + ".wav"时,

报错:UFuncTypeError: ufunc 'add' did not contain a loop with signature matching types (dtype('<U21'), dtype('<U21')) -> dtype('<U21')

查阅资料,大家说是因为数字和字符串格式不匹配导致的。比如这位博主写到的:Pandas | TypeError: ufunc ‘add‘ did not contain a loop with signature matching types dtype(‘<U21‘)…

检查了一下,我的音乐文件命名均是数字名,所以train_val.iloc[idx].name)的结果是数字,与".wav"字符串相加就会报错。
在这里插入图片描述

解决

于是,我将报错代码

train_val.iloc[idx].name)+ “.wav”

修改为:

str( train_val.iloc[idx].name ) + “.wav”

报错解决!

附:提取音乐文件的MFCC特征的代码

import librosa
from tqdm.notebook import tqdm 
import os

data_dir = 'audio_path'  # eg:'../dataset/'

# 训练音频的MFCC提取
tr_mfcc_vec = []
for idx in tqdm(range(len(train_val))):
    y, _ = librosa.load(os.path.join(data_dir, str(train_val.iloc[idx].name) + ".wav"), sr=22050)
    mfcc = librosa.feature.mfcc(y=y, sr=22050, n_fft=1024, hop_length=512, win_length=1024)
    tr_mfcc_vec.append(mfcc)
    
# 测试音频的MFCC提取
te_mfcc_vec = []
for idx in tqdm(range(len(test))):
    y, _ = librosa.load(os.path.join(data_dir, str(test.iloc[idx].name) + ".wav"), sr=22050)
    mfcc = librosa.feature.mfcc(y=y, sr=22050, n_fft=1024, hop_length=512, win_length=1024)
    te_mfcc_vec.append(mfcc)

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值