午夜剧场伦理_日本一道高清_国产又黄又硬_91黄色网战_女同久久另类69精品国产_妹妹的朋友在线

您的位置:首頁技術文章
文章詳情頁

Python使用pydub模塊轉換音頻格式以及對音頻進行剪輯

瀏覽:23日期:2022-06-17 17:52:56
前言

近端時間看了一個短視頻,覺得視頻的背景音樂片段很不錯,想把這個背景音樂得到,雖然小編運用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這個多媒體處理工具,否則,即使在代碼中指定音頻文件路徑沒有錯誤,運行結構也會報錯。如下:

Python使用pydub模塊轉換音頻格式以及對音頻進行剪輯

下載這個之后,就不會報這個錯誤了,下載網址為:ffmpeg

在這個網址下面找一個和自己電腦系統一樣的版本下載即可,下載完成之后,解壓,好像不配置環境變量,程序也可以正常執行,不過,最好還是配置環境變量。

Python使用pydub模塊轉換音頻格式以及對音頻進行剪輯

2.實現音頻剪輯和轉換音頻格式代碼

其實,實現音頻剪輯和轉換音頻格式的代碼總共就幾行代碼,只不過需要輸入一些參數值,因此代碼量相對而言多了起來。

關鍵代碼為:

from pydub import AudioSegmentsound=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=0elif ':' 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 # 毫秒作為單位,需要在原來秒數的基礎上再乘以1000if 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*=1000self.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比特率,百度了一下這個東西,好像對音頻音質有一定影響。

Python使用pydub模塊轉換音頻格式以及對音頻進行剪輯

3.總結

到此這篇關于Python使用pydub模塊轉換音頻格式以及對音頻進行剪輯的文章就介紹到這了,更多相關Python轉換音頻格式內容請搜索好吧啦網以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持好吧啦網!

標簽: Python 編程
相關文章:
主站蜘蛛池模板: 国产又大又猛 | 日韩一级片免费 | 国产中文字幕在线播放 | 一级二级在线观看 | 日韩在线无 | 久草国产视频 | 日韩av成人在线观看 | 免费亚洲视频 | 中文在线观看免费视频 | 激情网站在线 | 在线看片日韩 | www.av在线 | 黄色免费高清 | 超碰在线 | 国产又粗又猛又爽又黄的视频四季 | 国产特黄一级片 | 日韩精品999 | 欧美精品入口蜜桃 | 久久调教 | 四虎影视精品 | 国产在线导航 | beeg欧美| 日韩一区二区三区在线视频 | 国产五月天婷婷 | 欧美日韩999| 岛国av片| 美女日日日| 日韩黄大片 | 日韩不卡二区 | 91久热| 午夜啪啪网 | 一区二区三区免费在线观看视频 | 日本成人在线免费 | 91专区 | www.日韩在线 | 亚洲成人精品在线播放 | 五月婷婷六月激情 | 97久久人人 | 日韩在线免费观看视频 | 久久久久在线观看 | 这里只有精品视频 |