您当前的位置:首页 > IT编程 > python
| C语言 | Java | VB | VC | python | Android | TensorFlow | C++ | oracle | 学术与代码 | cnn卷积神经网络 | gnn | 图像修复 | Keras | 数据集 | Neo4j | 自然语言处理 | 深度学习 | 医学CAD | 医学影像 | 超参数 | pointnet | pytorch | 异常检测 | Transformers | 情感分类 | 知识图谱 |

自学教程:Python使用pydub模块转换音频格式以及对音频进行剪辑

51自学网 2021-10-30 22:34:46
  python
这篇教程Python使用pydub模块转换音频格式以及对音频进行剪辑写得很实用,希望能帮到您。

前言

近端时间看了一个短视频,觉得视频的背景音乐片段很不错,想把这个背景音乐得到,虽然小编运用Python爬虫肯定能得到这首音乐,但是这个音乐片段肯定是得不到的,于是网上看一下相关官方文档,没想到python真的有模块可以满足要求,这又让我想起自己CSDN界面的那段话了,“在Python面前,只有你想不到的,没有Python做不到的”。

1.需要下载的Python模块和ffmpeg多媒体处理工具

需要的Python模块是标题上提到的那个,pydub,这个模块可以实现对音频文件的剪辑、转换音频格式等。pydub是python的高级一个音频处理库,自带的wave模块只能处理 wav 格式的音频文件,如果要想处理类似MP3格式的文件,就得要装 ffmpeg或者libav了。pydub依赖于ffmpeg,这里选择安装ffmpeg。

下载命令,在cmd上输入pip install pydub即可

除了下载pydub这个模块之外,还需要下载ffmpeg这个多媒体处理工具,否则,即使在代码中指定音频文件路径没有错误,运行结构也会报错。如下:

下载这个之后,就不会报这个错误了,下载网址为:ffmpeg

在这个网址下面找一个和自己电脑系统一样的版本下载即可,下载完成之后,解压,好像不配置环境变量,程序也可以正常执行,不过,最好还是配置环境变量。

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 AudioSegmentimport sysclass 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

当然,这个模块好像还可以满足一些用户改变音乐音质的需求,export()方法里面有一个参数bitrate比特率,百度了一下这个东西,好像对音频音质有一定影响。

3.总结

到此这篇关于Python使用pydub模块转换音频格式以及对音频进行剪辑的文章就介绍到这了,更多相关Python转换音频格式内容请搜索51zixue.net以前的文章或继续浏览下面的相关文章希望大家以后多多支持51zixue.net!


PyQt5中QTimer定时器的实例代码
给numpy.array增加维度的超简单方法
万事OK自学网:51自学网_软件自学网_CAD自学网自学excel、自学PS、自学CAD、自学C语言、自学css3实例,是一个通过网络自主学习工作技能的自学平台,网友喜欢的软件自学网站。