攝影或3C

Python: 如何使用 pydub (dub:配音)將m4a 轉換為wav? 用 os.environ [ “PATH” ] 設定環境變量; from pydub import AudioSegment

ffmpeg 和 ffprobe 的路徑:
D:\user\Python\speech\ffmpeg-7.0.2-essentials_build\bin

code:

import os
from pydub import AudioSegment

# 设置 ffmpeg  ffprobe 的路径
ffmpeg_bin_path = r"D:\user\Python\speech\ffmpeg-7.0.2-essentials_build\bin"
os.environ["PATH"] += os.pathsep + ffmpeg_bin_path
AudioSegment.converter = ffmpeg_bin_path + r"\ffmpeg.exe"
AudioSegment.ffprobe = ffmpeg_bin_path + r"\ffprobe.exe"

# 指定源文件和目标文件路径
source_path = r"D:\user\Python\speech\我的錄音_中文測試.m4a"
target_path = r"D:\user\Python\speech\我的錄音_中文測試.wav"

# 加载 M4A 文件并导出为 WAV 文件
audio = AudioSegment.from_file(source_path, format="m4a")
audio.export(target_path, format="wav")
print(f"Converted {source_path} to {target_path}")

輸出結果:

環境變量配置:通過修改系統的 PATH 環境變量,使系統能夠識別到 ffmpeg 和 ffprobe 的路徑,進而讓 pydub 能夠正確使用這些工具來處理音頻文件。
設置 pydub 的 converter 和 ffprobe 屬性:直接指定 ffmpeg 和 ffprobe 的完整路徑,確保 pydub 無論環境變量是否正確設置都能正常工作。
音頻文件處理:
使用 from_file 函數加載源 M4A 文件。
使用 export 方法將音頻導出成 WAV 格式,這是 speech_recognition 庫能夠處理的格式之一。
輸出轉換信息:打印一條消息確認文件已被轉換和保存的位置。
這段代碼無需定義函數,直接執行所需的任務,適合簡單的使用場景。同時,它也保持了環境設置和文件轉換的清晰和直接,易於理解和維護。

在使用 pydub 这个音频处理库时,AudioSegment 类是用来处理音频文件的主要接口。在处理音频文件过程中,pydub 依赖于外部程序 ffmpeg 来执行许多底层操作,如格式转换、信息提取等。ffmpeg 是一个非常强大的多媒体框架,能够处理几乎所有类型的音视频数据。

AudioSegment.converter 和 AudioSegment.ffprobe 的作用:
AudioSegment.converter:
这个属性用于指定 ffmpeg 可执行文件的路径。ffmpeg 是核心工具,用于执行音频的解码、编码、转换等操作。当你需要将音频文件从一种格式转换成另一种格式,或者需要对音频数据进行处理时,pydub 会使用到 ffmpeg。
设置 AudioSegment.converter 为 ffmpeg 的路径是告诉 pydub 在哪里可以找到这个必需的外部工具。
AudioSegment.ffprobe:
ffprobe 是 ffmpeg 套件中的一个工具,用于收集和显示媒体文件的信息。这包括音频的比特率、持续时间、音频格式、编码类型等详细信息。
设置 AudioSegment.ffprobe 为 ffprobe 的路径是为了让 pydub 能够在需要获取音频文件的详细信息时调用这个工具。

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

儲蓄保險王

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