Python:运用pydub模块转换音频格式对音频进行剪辑
Posted il_持之以恒_li
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Python:运用pydub模块转换音频格式对音频进行剪辑相关的知识,希望对你有一定的参考价值。
Python:运用pydub模块转换音频格式、对音频进行剪辑
近端时间看了一个短视频,觉得视频的背景音乐片段很不错,想把这个背景音乐得到,虽然小编运用Python爬虫肯定能得到这首音乐,但是这个音乐片段肯定是得不到的,于是网上看一下相关官方文档,没想到python真的有模块可以满足要求,这又让我想起自己CSDN界面的那段话了,“在Python面前,只有你想不到的,没有Python做不到的”。
1.需要下载的Python模块和ffmpeg多媒体处理工具
需要的Python模块是标题上提到的那个,pydub,这个模块可以实现对音频文件的剪辑、转换音频格式等。
下载命令,在cmd上输入pip install pydub即可
除了下载pydub这个模块之外,还需要下载ffmpeg这个多媒体处理工具,否则,即使在代码中指定音频文件路径没有错误,运行结构也会报错。如下:
下载这个之后,就不会报这个错误了,下载网址为:ffmpeg
在这个网址下面找一个和自己电脑系统一样的版本下载即可,下载完成之后,解压,好像不配置环境变量,程序也可以正常执行,不过,最好还是配置环境变量。
对了,需要下载音乐的读者可以看看小编的专栏,专栏那里有python爬虫下载音乐的文章哈!专栏连接:爬虫
2.实现音频剪辑和转换音频格式代码
其实,实现音频剪辑和转换音频格式的代码总共就几行代码,只不过需要输入一些参数值,因此代码量相对而言多了起来。
关键代码为:
from pydub import Audiosegment
sound=AudioSegment.from_file(file='./music/刺客.mp3',format='mp3')
sound=sound[start:end] # start,end两个参数用于对音频进行剪辑
sound.export(out_f='./music/刺客.wav', format='wav') # 用于保存剪辑之后的音频文件
当然读者想了解更多有关这个模块的使用,可以来看看官方文档啊!
文档连接为:pydub
文档中讲了有关音频合并、音频重复等知识点喔!。
最终实现代码:
from pydub import AudioSegment
import sys
class Music(object):
def __init__(self,file,file_type,start,end,save_file,save_file_type):
self.sound = AudioSegment.from_file(file=file, format=file_type)
self.start=start # 剪辑音频文件开始时间
self.end=end # 剪辑音频文件的结束时间
self.save_file=save_file # 保存音频文件的路径
self.save_file_type=save_file_type # 保存音频文件的类型
def editedMusic(self): # 定义方法用于剪辑音频
# 对于传入的start,end参数进行一些字符串处理
## 对传入的开始时间进行字符串处理
if self.start=='0' or self.start=='': # 从头开始处理音频文件
start_time=0
elif ":" in self.start:# 从音频中间处理
list_1=self.start.split(":")
start_time=int(list_1[0])*60+int(list_1[1])
else: # 如果是其他情况,提示错误,并退出程序
print("你输入的初始截取时间有问题")
sys.exit()
start_time*=1000 # 毫秒作为单位,需要在原来秒数的基础上再乘以1000
if start_time>=len(self.sound): # 如果初始截取时间大于或等于音频文件总时间
print('你输入的初始截取时间大于该音频文件总时间,故无法进行剪辑操作')
sys.exit()
## 对传入的结束时间进行字符串处理
if self.end=='':
end_time=len(self.sound) # 如果输入结束时间为空,表示截取到音频文件最后
elif ':' in self.end:
list_2=self.end.split(':')
end_time=int(list_2[0])*60+int(list_2[1])
else:
print("你输入的结束截取时间有问题")
sys.exit()
end_time*=1000
self.sound=self.sound[start_time:end_time] # 对音频文件进行剪辑
self.saveFile()
def saveFile(self):
self.sound.export(out_f=self.save_file,format=self.save_file_type)
# 保存已经进行剪辑的音频文件
print('已成功转换!')
if __name__ == '__main__':
print('1.可以将音频文件转换其他格式的音频文件\\n2.可用剪辑音频文件\\n')
print('='*50)
file=input('建议:\\n(1.音频文件和运行文件在同一个文件夹下面,最好使用相对路径)\\n(2.音频文件和运行文件不在同一个文件夹下面,最好用绝对路径)\\n请输入要剪辑的文件路径:')
file_type=file[file.rfind('.')+1:] # 音频文件类型 mp3、wav
start=input("(可用输入0,空格,(1:1,1分1秒):)\\n输入开始截取时间:")
end=input("(可用输入空格,(1:1,1分1秒):)\\n输入结束截取时间:")
save_file=input("请输入剪辑之后保存的文件路径:")
save_file_type=save_file[save_file.rfind('.')+1:]
music=Music(file,file_type,start,end,save_file,save_file_type)
music.editedMusic() # 1:12 1:36
运行结果:
运用Python实现音频剪辑、音频格式转换
当然,这个模块好像还可以满足一些用户改变音乐音质的需求,export()方法里面有一个参数bitrate比特率,百度了一下这个东西,好像对音频音质有一定影响。
3.总结
如果读者有什么疑问,欢迎下方留言,当然也可以看官方文档,文档链接小编在上面已经给出。小编最近在参与新星计划,如果读者觉得小编的这篇文章还可以的话,记得点赞。
以上是关于Python:运用pydub模块转换音频格式对音频进行剪辑的主要内容,如果未能解决你的问题,请参考以下文章
普通话识别,mp3格式转wav, 采样率转换48000转16000,多通道转单通道,运用百度API,短音频,python