有些时候,为了设定手机铃声或者发抖音视频,咱们会消耗大量工夫在剪辑音乐低潮局部上。那么这个音乐低潮的提取能不能自动化呢?当然能够。
先来看看,怎么样来提取打成一片提取低潮后的局部:
怎么样,是不是急不可待想往下读了?不要急,让咱们从原理开始缓缓讲起。
1.原理简介
不晓得大家有没有这样的领会,大部分时候,歌曲的低潮局部通常是反复次数最多的局部。因而咱们能够依据这一个特色,提出咱们的算法:
1.遍历整首歌曲。
2.将选定长度的局部与其余局部比拟并计算类似度,以查看是否反复。
3.寻找反复次数较大、且距离长的片段。
2.代码编写
为了防止造轮子,咱们找到了他人曾经做过的相似的我的项目
咱们只须要剖析这个源代码中最外围的局部,即求类似区段的源代码,就能晓得它是不是合乎咱们的我的项目需要了:
能够看到,这部分代码就是做了咱们算法的第二步,进行了片段与片段之间的类似度计算。检测时用到的类似函数是这样的:
这次要是因为歌曲由12个根本音符的帧的汇合而组成,v1和v2是任意两段音乐的音符矢量,如果说两段音乐十分类似,那么左边的式子将靠近于0. 如果说 1-左边的式子 得分十分高,则阐明两段音乐十分类似。
上面咱们看看怎么应用这个我的项目求音乐低潮局部,其实非常简单。
2.1 装置所须要的我的项目
你能够通过pip装置该我的项目,如果你还没有装置好Python相干环境,倡议先装置,PIP装置指令如下:
pip install pychorus
2.2 编写代码
实际上,这个包用起来可是相当简略,如果咱们只是想单纯提取歌曲低潮局部:
from pychorus import find_and_output_choruschorus_start_sec = find_and_output_chorus("你的音乐文件", "提取后果的指标门路", 要多少秒的低潮局部)
没错,两行代码就解决了。如果你想晓得一些具体的细节,比如说输入相似矩阵或者后果可视化,倡议浏览github中该项目标操作指令。上面让咱们测验一下成果。
3.成果测验
以《打成一片》 为例,让咱们试试这个提取器的功力。
编写代码:
# 提取音乐低潮局部from pychorus import find_and_output_choruschorus_start_sec = find_and_output_chorus("打成一片.mp3", "打成一片_high.wav", 40)
十分优良!提取了我心目中想要的局部。大家也能够依据咱们明天的教程,试着提取一下本人喜爱的音乐的低潮局部哦!
4.批量提取
刚刚,只是实现了单首歌曲的低潮提取,如果你想提取整个文件夹下的音乐的低潮局部,能够这样做:
文字版代码:
# Python 实用宝典# 提取音乐低潮局部# 2020/06/11import osimport sysfrom pychorus import find_and_output_chorusdef extract_all_file(files_path): """ 批量提取音乐低潮 Args: files_path (str): 文件夹门路 """ # 文件夹门路 modpath = os.path.dirname(os.path.abspath(sys.argv[0])) for filepath in os.listdir(files_path): # 门路解决 datapath = os.path.join(modpath, files_path + filepath) # output文件夹是否存在 targets = f"{modpath}\output\" if not os.path.exists(targets): os.makedirs(targets) # 提取音乐低潮至以后output文件夹下 find_and_output_chorus( datapath, f"{targets}{filepath.split('.')[0]}_high.wav", 40 )extract_all_file("F:\push\20200611\music\")
如果你喜爱明天的Python 教程,请继续关注我,如果对你有帮忙,麻烦在上面点一个赞/关注,有任何问题都能够在下方留言,咱们会急躁解答的!