python 剪切音频

python 剪切音频

python 复制代码
import sys
import io
sys.stdout = io.TextIOWrapper(sys.stdout.buffer, encoding='utf-8')
from pydub import AudioSegment
import os

def cut_audio(input_file, start_time, end_time):
    """
    剪切音频文件
    :param input_file: 输入音频文件路径
    :param start_time: 开始时间(秒)
    :param end_time: 结束时间(秒)
    """
    try:
        # 检查文件是否存在
        if not os.path.exists(input_file):
            raise FileNotFoundError(f"找不到文件: {input_file}")

        # 加载音频文件
        print(f"正在加载音频文件: {input_file}")
        audio = AudioSegment.from_file(input_file)

        # 转换时间为毫秒
        start_ms = int(float(start_time) * 1000)
        end_ms = int(float(end_time) * 1000)

        # 验证时间范围
        if start_ms >= end_ms:
            raise ValueError("开始时间必须小于结束时间")
        
        if end_ms > len(audio):
            raise ValueError(f"结束时间超出音频长度 ({len(audio)/1000:.2f}秒)")

        # 执行剪切
        print(f"正在剪切音频: {start_time}秒 到 {end_time}秒")
        cut_audio = audio[start_ms:end_ms]

        # 生成输出文件名
        file_name = os.path.splitext(input_file)[0]
        output_file = f"{file_name}_cut_{start_time}-{end_time}.mp3"

        # 导出文件
        print(f"正在保存文件: {output_file}")
        cut_audio.export(output_file, format="mp3")
        
        print(f"剪切完成!输出文件: {output_file}")
        return True

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

def main():
    # 检查参数数量
    if len(sys.argv) != 4:
        print("使用方法: python script.py <音频文件> <开始时间(秒)> <结束时间(秒)>")
        print("示例: python script.py input.mp3 10 30")
        return

    # 获取参数
    input_file = sys.argv[1]
    start_time = sys.argv[2]
    end_time = sys.argv[3]

    # 执行剪切
    cut_audio(input_file, start_time, end_time)

if __name__ == "__main__":
    # main()
    cut_audio("output.wav", 11, 15)
相关推荐
a2006380127 分钟前
ply(python版本的flex/bison or Lex/Yacc)
python
王道长服务器 | 亚马逊云8 分钟前
AWS Elemental MediaConvert:视频转码不再难
linux·服务器·网络·云计算·音视频·aws
wokaoyan198113 分钟前
逻辑推演题——谁是骗子
python
九年义务漏网鲨鱼14 分钟前
利用AI大模型重构陈旧代码库 (Refactoring Legacy Codebase with AI)
python
DemonAvenger26 分钟前
深入Redis String:从基础到实战,10年经验的后端工程师带你解锁最佳实践
数据库·redis·性能优化
滑水滑成滑头26 分钟前
**标题:发散创新:智能交通系统的深度探究与实现**摘要:本文将详细
java·人工智能·python
shuair32 分钟前
redis大key问题
数据库·redis·缓存
SelectDB42 分钟前
Apache Doris 4.0 版本正式发布:全面升级 AI 与搜索能力,强化离线计算
数据库·数据分析·apache
SelectDB1 小时前
从 Snowflake 到 Apache Doris:Planet 实时分析成本直降 80%、查询加速 90 倍
数据库·数据分析·apache
闭着眼睛学算法1 小时前
【双机位A卷】华为OD笔试之【哈希表】双机位A-跳房子I【Py/Java/C++/C/JS/Go六种语言】【欧弟算法】全网注释最详细分类最全的华子OD真题题解
java·c语言·c++·python·算法·华为od·散列表