python將音頻進(jìn)行變速的操作方法
有的時(shí)候需要手里的音頻文件變速聽(tīng),或可能變慢或可能變快
這里使用的python進(jìn)行操作,我的目標(biāo)是將文件轉(zhuǎn)成2倍速
首先需要安裝插件
pip install ffmpeg
然后再執(zhí)行:
from ffmpeg import audio
audio.a_speed("D:\\1505.mp3", "2", "D:\\1505_2x.mp3")
如果執(zhí)行不出錯(cuò),會(huì)返回一個(gè)true
運(yùn)行結(jié)果

我可以看到這里的音頻速度提升以后音頻小了
這里我是將目標(biāo)路徑下的MP3音頻轉(zhuǎn)成了2倍速的,設(shè)立不局限于MP3。其他格式的音頻文件也是可以進(jìn)行處理的。
當(dāng)然這里還可以進(jìn)行批量操作
import os import sys from ffmpeg import audio audio_path = "D:\\audio\\" finish_path = "D:\\2x_audio\\" def run(): audio_file = os.listdir(audio_path) for i, audio1 in enumerate(audio_file): print(audio_path+audio1) audio.a_speed(audio_path+audio1, "2", finish_path+"2x"+audio1) run()
實(shí)際上這個(gè)的源碼干了一件這個(gè)事情
import subprocess # 調(diào)整音頻播放速率 def a_speed(input_file, speed, out_file): try: cmd = "ffmpeg -y -i %s -filter_complex \"atempo=tempo=%s\" %s" % (input_file, speed, out_file) res = subprocess.call(cmd, shell=True) if res != 0: return False return True except Exception: return False
實(shí)際可以看到,使用的f調(diào)用的原生的fmpeg,也就是基于fmpeg開(kāi)發(fā)的
不過(guò)好像我發(fā)現(xiàn),如果音頻文件太大會(huì)失敗,返回false
我試過(guò)原生的fmpeg是可以進(jìn)行的,只是會(huì)轉(zhuǎn)換很慢
D:\>ffmpeg -n -i 222.mp3 -filter:a "atempo=2" output.mp3
現(xiàn)在不知道是不是因?yàn)橄拗屏舜笮。ìF(xiàn)在猜測(cè)可能是顯示了大或者限制了響應(yīng)時(shí)間大小,在源碼里沒(méi)有發(fā)現(xiàn)什么詭異的地方),音頻不算大的是沒(méi)問(wèn)題的,我試的單個(gè)文件是100多兆的文件,會(huì)失敗,但是10m是沒(méi)有問(wèn)題的。
實(shí)在不行就直接用原生的好了
import os import sys #from ffmpeg import audio audio_path = "D:\\audio\\" finish_path = "D:\\2x_audio\\" def run(): audio_file = os.listdir(audio_path) for i, audio1 in enumerate(audio_file): #print(audio_path+audio1) cmd="ffmpeg -n -i "+audio_path+audio1+" -filter:a atempo=2 "+finish_path+"2x"+audio1 #print(cmd) os.system(cmd) #audio.a_speed(audio_path+audio1, "2", finish_path+"2x"+audio1) run()
后來(lái)發(fā)現(xiàn),最好音頻的文件名不要有漢字
上面另兩個(gè)代碼應(yīng)該都是可以的
總結(jié)
到此這篇關(guān)于python將音頻進(jìn)行變速的操作方法的文章就介紹到這了,更多相關(guān)python 音頻變速內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
python爬蟲(chóng)之利用Selenium+Requests爬取拉勾網(wǎng)
這篇文章主要介紹了python爬蟲(chóng)之利用Selenium+Requests爬取拉勾網(wǎng),文中有非常詳細(xì)的代碼示例,對(duì)正在學(xué)習(xí)python爬蟲(chóng)的小伙伴們有很好的幫助,需要的朋友可以參考下2021-04-04
python中l(wèi)xml.etree 和 ElementTree 的區(qū)別解析
lxml.etree 提供了更多的功能,例如 XPath、XSLT、Relax NG、 和 XML 模式支持,etree 對(duì) Python unicode 字符串的想法與 ElementTree 不同,本文給大家介紹python中l(wèi)xml.etree 和 ElementTree 的區(qū)別,感興趣的朋友一起看看吧2024-01-01
解決TensorFlow模型恢復(fù)報(bào)錯(cuò)的問(wèn)題
今天小編就為大家分享一篇解決TensorFlow模型恢復(fù)報(bào)錯(cuò)的問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2020-02-02
Python實(shí)現(xiàn)給文件添加內(nèi)容及得到文件信息的方法

