攝影或3C

Python: 如何使用pydub切割音檔? from pydub import AudioSegment ; from pydub.silence import split_on_silence

code:

# -*- coding: utf-8 -*-
"""
Created on Thu Sep  5 20:21:03 2024

@author: SavingKing
"""

from pydub import AudioSegment
from pydub.silence import split_on_silence
import os
import time

def mkdir_export(dirname, strr="export"):
    dirname_export = os.path.join(dirname, strr)
    if not os.path.exists(dirname_export):
        os.mkdir(dirname_export)
        print(f"已經建立資料夾: {dirname_export}")
    else:
        print(f"資料夾已經存在: {dirname_export}")
    return dirname_export
    
dirname = r"P:\My Documents\Jeff\錄\copy\Jeff240606"
basename_wav = "Jeff240606.wav"
path_wav = os.path.join(dirname, basename_wav)

dir_split = mkdir_export(dirname, strr="split")

# 加载音频文件
audio = AudioSegment.from_wav(path_wav)

start_time = time.time()
print("分割音檔中...")
# 使用静默检测来分割音频
chunks = split_on_silence(
    audio,
    min_silence_len=500,  # 至少需要持续半秒的静默才视为分割点
    silence_thresh=audio.dBFS-14,  # 小于-70 dBFS 的静默视为静默
    #静音阈值是当前音频文件平均分贝dBFS减去 14 dB
    #这是一个相对值依赖于原始音频文件的平均音量水平
    keep_silence=500,  # 保留静默500毫秒到分割的音频片段
)
#type(chunks[0])
#Out[13]: pydub.audio_segment.AudioSegment

basename_main = os.path.splitext(basename_wav)[0]
# 处理每个分割后的音频片段
for i, chunk in enumerate(chunks):
    out_file = f"{basename_main}_{i}.wav"
    #out_file = f"chunk{i}.wav"
    print(f"正在處理 {out_file}")
    chunk.export(os.path.join(dir_split, out_file), format="wav")

end_time = time.time()
elapsed_time = end_time - start_time
print(f"分割的音檔已經輸出到 {dir_split}")
print(f"耗时 {round(elapsed_time, 2)} 秒")

輸出結果:

推薦hahow線上學習python: https://igrape.net/30afN

儲蓄保險王

儲蓄險是板主最喜愛的儲蓄工具,最喜愛的投資理財工具則是ETF,最喜愛的省錢工具則是信用卡