AudioSegment 将音频分割为指定长度时间片段 - python 实现

DataBall 助力快速掌握数据集的信息和使用方式,会员享有 百种数据集,持续增加中。

需要更多数据资源和技术解决方案,知识星球: "DataBall - X 数据球(free)"

-----------------------------------------------------------------------------------------

AudioSegment 将音频切割为指定长度时间片段。

python 复制代码
# -*-coding:utf-8-*-
# date:2024-12
# Author: DataBall - XIAN
# Function:将音频切割为指定长度时间片段

from pydub import AudioSegment

audio_path = 'audio/test.mp3'

# 加载音频文件
audio = AudioSegment.from_file(audio_path)

# 确定每个音频切割音频片段的长度(秒)
chunk_length_seconds = 20  # 假设每段音频长度为20秒

# 计算需要切割的片段数量
num_chunks = int(len(audio) / 1000 / chunk_length_seconds)  # len(audio)返回的是毫秒数

# 切割音频并保存每个片段
for i in range(num_chunks):
    start_ms = i * chunk_length_seconds * 1000  # 将秒转换为毫秒
    chunk = audio[start_ms:start_ms + chunk_length_seconds * 1000]  # 切割音频片段
    chunk.export(f'clip_audio/chunk_{i+1}.mp3', format='mp3')  # 导出音频片段

# 如果音频的总长度不是chunk_length_seconds的整数倍,会剩下一部分音频没有被切割
# 处理剩余的音频
remaining_ms = len(audio) - num_chunks * chunk_length_seconds * 1000
if remaining_ms > 0:
    remaining_chunk = audio[(-remaining_ms):]
    remaining_chunk.export(f'clip_audio/chunk_{num_chunks + 1}.mp3', format='mp3')

​​​​​

助力快速掌握数据集的信息和使用方式。

数据可以如此美好!

相关推荐
无心水13 小时前
【java开发常见错误】5、HTTP调用避坑指南:超时、重试、并发,一个都不能少
java·开发语言·后端·http·架构师·http调用·后端开发错误
炸膛坦客13 小时前
单片机/C语言八股:(五)32/64 位系统中,C/C++各变量类型所占字节数
c语言·开发语言·c++
所谓伊人,在水一方33313 小时前
【Python数据可视化精通】第11讲 | 可视化系统架构与工程实践
开发语言·python·信息可视化·数据分析·系统架构·pandas
iPadiPhone13 小时前
Java 泛型与通配符全链路解析及面试进阶
java·开发语言·后端·面试
ArturiaZ13 小时前
【day53】
开发语言·c++·算法
历程里程碑13 小时前
36 Linux线程池实战:日志与策略模式解析
开发语言·数据结构·数据库·c++·算法·leetcode·哈希算法
haiyaoyouyou13 小时前
Qt ElaWidgetTools 编译运行示例
开发语言·qt·qt creator·elaframework·mingw_64
lzp079113 小时前
python爬虫——爬取全年天气数据并做可视化分析
开发语言·爬虫·python
会编程的土豆13 小时前
C语言实现:影院票务管理系统(铠甲怪兽管理系统)(详细解析+效果展示)C语言实现:影院票务管理系统(铠甲怪兽管理系统)(详细解析+效果展示)
c语言·开发语言·课程设计·项目·管理系统
2301_7890156213 小时前
DS进阶:红黑树
c语言·开发语言·数据结构·c++·算法·r-tree·lsm-tree