求python将两个MP3音频文件拼接成一个MP3文件的代码

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了求python将两个MP3音频文件拼接成一个MP3文件的代码相关的知识,希望对你有一定的参考价值。

可以使用pydub

1 网址:https://github.com/jiaaro/pydub

2 pydub需要依赖 libav或者ffmpeg

3 在mac环境下安装依赖:(二选一)

[plain] view plaincopy

brew install libav --with-libvorbis --with-sdl --with-theora  

将所有依赖都安装上~~  

brew install ffmpeg --with-fdk-aac --with-ffplay --with-freetype --with-frei0r --with-libass --with-libvo-aacenc --with-libvorbis--with-libvpx --with-opencore-amr --with-openjpeg --with-opus --with-rtmpdump --with-schroedinger --with-speex --with-theora --with-tools --with-fdk-aac --with-freetype --with-ffplay --with-ffplay --with-freetype --with-frei0r --with-libass --with-libbluray --with-libcaca --with-libquvi --with-libvidstab --with-libvo-aacenc --with-libvorbis --with-libvpx --with-opencore-amr --with-openjpeg --with-openssl --with-opus --with-rtmpdump --with-schroedinger --with-speex --with-theora --with-tools --with-x265  

4 安装pydub:  pip install pydub

5 使用pydub:

下载是示代码

enPath = "%s%s/%s"%(enDir,file,enfile) #英文文件的路径
cnPath = "%s%s/%s"%(cnDir,file,enfile.replace("en_w","cn_w"))#中文文件的路径
targetPath = "%s%s/%s"%(toDir,file,enfile.replace("en_w","all")) #合并文件的路径
#加载MP3文件
song1 = Audiosegment.from_mp3(enPath)
song2 = AudioSegment.from_mp3(cnPath)

#取得两个MP3文件的声音分贝
db1 = song1.dBFS
db2 = song2.dBFS

song1 = song1[300:] #从300ms开始截取英文MP3

#调整两个MP3的声音大小,防止出现一个声音大一个声音小的情况
dbplus = db1 - db2
if dbplus < 0: # song1的声音更小
song1+=abs(dbplus)
elif dbplus > 0: #song2的声音更小
song2+=abs(dbplus)

#拼接两个音频文件
song = song1 + song2

#导出音频文件
song.export(targetPath, format="mp3") #导出为MP3格式
参考技术A 建议用别人现成的库,不过这个库依赖于ffmpeg或avconv。在win32上不一定好安装。其实这些工作用ffmpeg的命令行也很容易实现。

from pydub import AudioSegment

sound = AudioSegment.from_mp3("/path/to/file.mp3")

# len() and slicing are in milliseconds
halfway_point = len(sound) / 2
second_half = sound[halfway_point:]

# Concatenation is just adding
second_half_3_times = second_half + second_half + second_half

# writing mp3 files is a one liner
second_half_3_times.export("/path/to/new/file.mp3", format="mp3")本回答被提问者和网友采纳

怎么通过ffmpeg将音频文件转换成Mp3 转

参考技术A 可以的。用千千静听、GOLDWAVE、全能音频转换通都可以。
用千千静听转换的步骤:
把要转换的歌曲添加进千千的媒体库,
右键单击歌曲名--转换格式--默认就是输出MP3格式。
如果需要多首同时转换,只需要按住CTRL键,依次点击这些歌曲名就可以了。
可能是输入的pcm或输出MP3没有指定采样率和频道参数
把样本发一个给我可以看看

以上是关于求python将两个MP3音频文件拼接成一个MP3文件的代码的主要内容,如果未能解决你的问题,请参考以下文章

拆分音频 MP3 文件 [关闭]

怎么通过ffmpeg将音频文件转换成Mp3 转

网易云音乐文件,怎么转换成mp3格式?

如何将wav转换成mp3音频格式?

如何将m4a音频换成mp3格式

怎么通过ffmpeg将音频文件转换成Mp3 转