Python 如何實現批量轉換視頻音頻的采樣率

前言

本文主要分享一個python代碼,可以將多個視頻中的音頻轉化為相同采樣率的視頻。對視頻格式的校驗沒有做,也不是很關鍵。

環境依賴

ffmpeg環境安裝

ffmpy安裝:

pip install ffmpy -i https://pypi.douban.com/simple

代碼

不廢話,上代碼。

#!/user/bin/env python
# coding=utf-8
"""
@project : csdn
@author  : 劍客阿良_ALiang
@file   : transfor_mp4_audio_sampling_rate.py
@ide    : PyCharm
@time   : 2021-11-24 13:48:08
"""
from ffmpy import FFmpeg
import os
 
 
def transfor(video_path: str, tmp_dir: str, result_dir: str):
    file_name = os.path.basename(video_path)
    base_name = file_name.split('.')[0]
    file_ext = file_name.split('.')[-1]
    ext = 'wav'
 
    audio_path = os.path.join(tmp_dir, '{}.{}'.format(base_name, ext))
    print('文件名:{},提取音頻'.format(audio_path))
    ff = FFmpeg(
        inputs={
            video_path: None}, outputs={
            audio_path: '-f {} -vn -ac 1 -ar 16000 -y'.format('wav')})
    print(ff.cmd)
    ff.run()
 
    if os.path.exists(audio_path) is False:
        return None
 
    video_tmp_path = os.path.join(
        tmp_dir, '{}_1.{}'.format(
            base_name, file_ext))
    ff_video = FFmpeg(inputs={video_path: None},
                      outputs={video_tmp_path: '-an'})
    print(ff_video.cmd)
    ff_video.run()
 
    result_video_path = os.path.join(result_dir, file_name)
    ff_fuse = FFmpeg(inputs={video_tmp_path: None, audio_path: None}, outputs={
        result_video_path: '-map 0:v -map 1:a -c:v copy -c:a aac -shortest'})
    print(ff_fuse.cmd)
    ff_fuse.run()
    return result_video_path
 
 
def handle(video_dir: str, tmp_dir: str, result_dir: str):
    if os.path.isdir(video_dir):
        for file in os.listdir(video_dir):
            try:
                result = transfor(
                    os.path.join(
                        video_dir,
                        file),
                    tmp_dir,
                    result_dir)
            except Exception as e:
                print(e)
                continue
            if result:
                print(result)
 
 
if __name__ == '__main__':
    handle(
        'C:/Users/huyi/Desktop/shipin',
        'C:/Users/huyi/Desktop/tmp',
        'C:/Users/huyi/Desktop/result')

代碼說明

1、handle方法入參分別為:視頻目錄、臨時目錄、最終結果視頻目錄。

2、handle方法會遍歷視頻目錄,一次對視頻做transfor方法處理,步驟為:(1)提取視頻音頻並轉化為定義的采樣率音頻;(2)提取視頻中不帶音頻的視頻;(3)融合新視頻與新音頻合成最終視頻到指定的結果目錄。

3、沒有音頻的異常直接丟棄,無需進行轉換。

4、最終結果目錄的文件名與原視頻目錄的文件名一致。

5、該代碼主要轉化為16k采樣率,可以按照需求調整。

驗證一下

原始視頻采樣率

結果視頻采樣率

到此這篇關於Python 如何實現批量轉換視頻音頻的采樣率的文章就介紹到這瞭,更多相關Python 批量轉換視頻音頻采樣率內容請搜索WalkonNet以前的文章或繼續瀏覽下面的相關文章希望大傢以後多多支持WalkonNet!

推薦閱讀: