ffmpeg切割音频

ffmpeg切割音频

我希望对指定音频切割,按照开始时间,结束时间,切割成新文件,自动保存,非常好用

step1:

python 复制代码
from pydub import AudioSegment
import os

# 配置FFmpeg路径(确保路径正确)
ffmpeg_path = r"C:\ffmpeg\bin\ffmpeg.exe"
if os.path.exists(ffmpeg_path):
    AudioSegment.converter = ffmpeg_path
else:
    print("警告:未找到FFmpeg,将尝试使用系统路径中的FFmpeg")


def trim_audio_file(input_path, output_path, start_time=0, end_time=20):
    """
    剪切单个音频文件的指定时间段

    参数:
    input_path: 输入文件路径
    output_path: 输出文件路径
    start_time: 开始时间(秒),默认为0
    end_time: 结束时间(秒),默认为20
    """
    try:
        # 验证输入文件存在
        if not os.path.exists(input_path):
            raise FileNotFoundError(f"输入文件不存在: {input_path}")

        # 获取文件扩展名
        ext = os.path.splitext(input_path)[1].lower()
        supported_extensions = ['.mp3', '.wav', '.flac', '.ogg', '.m4a']
        if ext not in supported_extensions:
            raise ValueError(f"不支持的音频格式: {ext}")

        print(f"正在处理: {os.path.basename(input_path)}")

        # 加载音频文件
        audio = AudioSegment.from_file(input_path)
        original_duration = audio.duration_seconds
        print(f"原始文件时长: {original_duration:.2f}秒")

        # 转换为毫秒
        start_ms = start_time * 1000
        end_ms = end_time * 1000

        # 验证时间范围
        if start_ms < 0:
            start_ms = 0
            print(f"警告: 开始时间调整为0秒")

        if end_ms > len(audio):
            end_ms = len(audio)
            print(f"警告: 结束时间调整为文件末尾 ({end_ms / 1000:.2f}秒)")

        if start_ms >= end_ms:
            raise ValueError(f"无效的时间范围: {start_time}s-{end_time}s")

        # 剪切音频
        trimmed_audio = audio[start_ms:end_ms]

        # 确保输出目录存在
        os.makedirs(os.path.dirname(output_path), exist_ok=True)

        # 导出文件
        trimmed_audio.export(output_path, format=ext[1:])

        print(f"成功剪切: {start_time}s - {end_time}s")
        print(f"输出文件时长: {trimmed_audio.duration_seconds:.2f}秒")
        print(f"已保存至: {output_path}")

        return True

    except Exception as e:
        print(f"处理出错: {str(e)}")
        return False


if __name__ == "__main__":
    # 固定文件路径
    input_path = r"D:\Users\wangrusheng\Downloads\r.mp3"  # TXT文件路径
    output_path = r"D:\Users\wangrusheng\Downloads\rad.mp3"  # TXT文件路径
    # 固定时间范围 (0-20秒)
    start_time = 0
    end_time = 60

    print("音频文件剪切工具")
    print("=" * 40)
    print(f"输入文件: {input_path}")
    print(f"输出文件: {output_path}")
    print(f"剪切范围: {start_time}秒 - {end_time}秒")

    # 处理文件
    print("\n开始处理...")
    success = trim_audio_file(input_path, output_path, start_time, end_time)

    if success:
        print("\n处理完成!")
    else:
        print("\n处理失败,请检查错误信息")

end

相关推荐
筏.k2 小时前
FFmpeg 核心 API 系列:avcodec_find_decoder / avcodec_alloc_context3 / avcodec_open2
ffmpeg
reasonsummer4 小时前
【办公类-117-01】20250924通义万相视频2.5——三个小人(幼儿作品动态化)
人工智能·音视频·通义万相
Everbrilliant894 小时前
Xcode上编译调试ffmpeg
macos·ffmpeg·xcode·ffmpeg源码编译工具·xcode调试ffmpeg源码·ffmpeg工具环境变量配置
摸鱼仙人~5 小时前
如何高效下载 YouTube 视频?实用工具推荐
音视频
molihuan10 小时前
开源 全平台 哔哩哔哩缓存视频合并 Github地址:https://github.com/molihuan/hlbmerge_flutter
android·flutter·缓存·ffmpeg·开源·github·音视频
AI视觉网奇12 小时前
pyqt 播放视频遮罩显示 时钟
音视频·pyqt
ulimate_12 小时前
树莓派无法播放哔哩哔哩等视频
音视频
DogDaoDao15 小时前
DCT与DST变换原理及其在音视频编码中的应用解析
音视频·实时音视频·视频编解码·dct变换·变换编码·dst变换
PythonFun15 小时前
从零开始,用WPS和DeepSeek打造数字人科普视频
音视频·wps
Dxy123931021621 小时前
python如何通过链接下载保存视频
python·spring·音视频