广告
返回顶部
首页 > 资讯 > 后端开发 > Python >Python音频处理库pydub如何使用
  • 213
分享到

Python音频处理库pydub如何使用

2023-07-05 15:07:22 213人浏览 安东尼

Python 官方文档:入门教程 => 点击学习

摘要

本篇内容主要讲解“python音频处理库pydub如何使用”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Python音频处理库pydub如何使用”吧!1. 安装使用pip安装即可(还需安装FFm

本篇内容主要讲解“python音频处理库pydub如何使用”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习Python音频处理库pydub如何使用”吧!

    1. 安装

    使用pip安装即可(还需安装FFmpeg依赖,建议使用conda命令安装,则不需要配置环境):

    pip install pydub

    2. 导入和读取音频文件

    from pydub import AudiOSegmentaudio = AudioSegment.from_file("path/to/file")

    3. 播放音频

    from pydub.playback import playplay(audio)

    4. 音频时长

    duration = audio.duration_seconds # 单位为秒

    5. 音频切割

    # 前10秒audio = audio[:10000]# 后10秒audio = audio[-10000:]# 从第10秒开始到第20秒结束audio = audio[10000:20000]# 从第10秒开始到结尾audio = audio[10000:]# 从开始到第10秒audio = audio[:10000]

    6. 音频合并

    audio1 = AudioSegment.from_file("path/to/file1")audio2 = AudioSegment.from_file("path/to/file2")audio_combined = audio1 + audio2

    7. 音频转换

    audio.export("path/to/new/file", fORMat="mp3")

    8. 调整音量

    # 增加10分贝louder_audio = audio + 10# 减小10分贝quieter_audio = audio - 10

    9. 等分分割音频

    # 等分分割,按大概每三分钟进行分割for i in range(1, 1000):    if 3.3 >= (audio.duration_seconds / (60 * i)) >= 2.8:        number = i        breakchunks = audio[::int(audio.duration_seconds / number * 1000 + 1)]  # 切割# 保存分割后的音频for i, chunk in enumerate(chunks):    chunk.export("path/to/new/file{}.wav".format(title,i), format="wav")

    10. 完整代码

    下面是一段完整的代码,用于对音频进行前后切割,并将音频分割成合适长度的小段进行保存。

    from pydub import AudioSegment# 读取音频文件audio = AudioSegment.from_file("path/to/file")# 输出视频时长print('视频时长:', audio.duration_seconds / 60)# 前后切割start = int(input('前切割n秒,不切割输入0'))*1000end = int(input('后切割n秒,不切割输入0'))*1000if start:    audio = audio[start:-end]# 计算合适的分割长度for i in range(1, 1000):    if 3.3 >= (audio.duration_seconds / (60 * i)) >= 2.8:        number = i        breakchunks = audio[::int(audio.duration_seconds / number * 1000 + 1)] # 保存分割后的音频for i, chunk in enumerate(chunks):    print('分割后的时长:', chunk.duration_seconds / 60)    chunk.export("path/to/new/file{}.wav".format(i), format="wav")

    以上就是pydub的主要知识点和一个完整的实例。通过pydub,我们可以方便地对音频进行处理和转换,让我们的音频处理更加高效和便捷。
    另外,下面还列举了一些pydub的其他应用案例。

    应用案例

    1. 将音频文件转换为指定格式

    from pydub import AudioSegment# 读取音频文件audio = AudioSegment.from_file("path/to/file")# 转换为mp3格式并保存audio.export("path/to/new/file.mp3", format="mp3")

    2. 将多个音频文件合并为一个文件

    from pydub import AudioSegment# 读取音频文件audio1 = AudioSegment.from_file("path/to/file1")audio2 = AudioSegment.from_file("path/to/file2")# 合并音频文件并保存combined_audio = audio1 + audio2combined_audio.export("path/to/new/file", format="wav")

    3. 制作铃声

    from pydub import AudioSegment# 读取音频文件audio = AudioSegment.from_file("path/to/file")# 切割并保存start = 10000end = 15000ringtone = audio[start:end]ringtone.export("path/to/new/file", format="mp3")

    4. 调整音频音量

    from pydub import AudioSegment# 读取音频文件audio = AudioSegment.from_file("path/to/file")# 增加10分贝louder_audio = audio + 10# 减小10分贝quieter_audio = audio - 10# 保存调整后的音频louder_audio.export("path/to/new/file", format="wav")quieter_audio.export("path/to/new/file", format="wav")

    案例:通过识别空白音,分割音频中的歌曲

    from pydub import AudioSegmentfrom pydub.silence import split_on_silence# 读取音频文件audio = AudioSegment.from_file("audio.mp3", format="mp3")# 设置分割参数min_silence_len = 700  # 最小静音长度silence_thresh =-10  # 静音阈值,越小越严格keep_silence = 600  # 保留静音长度# 计算分割数量num_segments = int(audio.duration_seconds/60/3)  # 每首歌曲大概三分钟,计算歌曲数量# 分割音频文件for i in range(-10, 0):    segments = split_on_silence(audio, min_silence_len=min_silence_len, silence_thresh=i, keep_silence=keep_silence)    if len(segments) <= num_segments:        print(f"分割成功,共分割出 {len(segments)} 段")        break    else:        print(f"当前阈值为 {i},分割出 {len(segments)} 段,继续尝试")

    首先,我们使用AudioSegment.from_file()方法读取音频文件,并设置分割参数min_silence_len、silence_thresh和keep_silence分别表示最小静音长度、静音阈值和保留静音长度。其中,静音阈值越小,分割出的小段越多,但可能会出现误分割的情况;反之,静音阈值越大,分割出的小段越少,但可能会出现漏分割的情况。

    然后,我们计算分割数量num_segments,即将音频文件分割成多少段。这里我们假设每首歌曲大概三分钟,计算出总共需要分割成多少段。

    最后,我们使用split_on_silence()方法对音频文件进行分割,设置分割参数,并通过循环来不断调整静音阈值,直到分割出的小段数量符合预期为止。如果分割成功,则跳出循环;否则,继续尝试。

    总而言之,pydub是一个非常实用的音频处理库,可以方便地进行音频处理、转换、合并等操作。同时,pydub还有丰富的应用场景,如制作铃声、调整音量等。值得注意的是,在使用pydub的过程中,需要注意音频格式的兼容性问题。

    此外,还可以通过pydub对音频进行编解码、混音、重采样等操作。下面是一些常见的操作示例。

    编解码、混音、重采样

    编解码

    from pydub import AudioSegment# 读取音频文件audio = AudioSegment.from_file("path/to/file")# 编码encoded_audio = audio.set_frame_rate(16000).set_sample_width(2).set_channels(1)# 解码decoded_audio = encoded_audio.set_frame_rate(44100).set_sample_width(4).set_channels(2)

    混音

    from pydub import AudioSegment# 读取音频文件audio1 = AudioSegment.from_file("path/to/file1")audio2 = AudioSegment.from_file("path/to/file2")# 混音mixed_audio = audio1.overlay(audio2)# 保存混音后的音频mixed_audio.export("path/to/new/file", format="wav")

    重采样

    from pydub import AudioSegment# 读取音频文件audio =AudioSegment.from_file("path/to/file")# 重采样为44100Hzresampled_audio = audio.set_frame_rate(44100)# 保存重采样后的音频resampled_audio.export("path/to/new/file", format="wav")

    通过pydub,我们可以方便地进行音频编解码、混音、重采样等操作,进一步扩展了pydub的应用场景。需要注意的是,在进行音频混音操作时,需要保证两个音频文件的采样率、采样位数和声道数相同。

    最后,总结一下pydub的优点和缺点。

    优点:

    轻量级:pydub是一个轻量级的音频处理库,安装方便,使用简单。

    功能丰富:pydub提供了丰富的音频处理功能,包括切割、合并、转换、调整音量、编解码、混音、重采样等。

    应用广泛:pydub的应用场景非常广泛,包括音频处理、铃声制作、音频格式转换、语音识别等等。

    缺点:

    对格式的兼容性有限:pydub对音频格式的兼容性有限,不支持所有的音频格式,需要先将音频转换为支持的格式后才能进行处理。

    性能一般:pydub在处理大文件时,性能可能会比较一般,需要耗费一定的时间和计算资源。

    不支持流式处理:pydub不支持流式处理,需要将整个音频文件读取到内存中,导致内存占用较大。

    综上所述,pydub是一个功能丰富、应用广泛的音频处理库。在使用pydub时,需要注意音频格式的兼容性问题,并注意处理大文件时的性能和内存占用。如果需要处理更复杂的音频任务,可以考虑使用其他更专业的音频处理库。

    到此,相信大家对“Python音频处理库pydub如何使用”有了更深的了解,不妨来实际操作一番吧!这里是编程网网站,更多相关内容可以进入相关频道进行查询,关注我们,继续学习!

    --结束END--

    本文标题: Python音频处理库pydub如何使用

    本文链接: https://www.lsjlt.com/news/352481.html(转载时请注明来源链接)

    有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

    本篇文章演示代码以及资料文档资料下载

    下载Word文档到电脑,方便收藏和打印~

    下载Word文档
    猜你喜欢
    • Python音频处理库pydub如何使用
      本篇内容主要讲解“Python音频处理库pydub如何使用”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Python音频处理库pydub如何使用”吧!1. 安装使用pip安装即可(还需安装ffm...
      99+
      2023-07-05
    • Python音频处理——pydub
      Pydub是Python音频处理库,可以对音频进行切割、合并、转换、调整音量等操作。以下是对pydub各个知识点的介绍和案例。 Pydub 1. 安装 使用pip安装即可(还需安装ffmpeg依赖,建...
      99+
      2023-09-09
      ffmpeg python 开发语言
    • Python音频处理库pydub的使用教程详解
      目录1. 安装2. 导入和读取音频文件3. 播放音频4. 音频时长5. 音频切割6. 音频合并7. 音频转换8. 调整音量9. 等分分割音频10. 完整代码应用案例1. 将音频文件转...
      99+
      2023-03-22
      Python音频处理库pydub Python音频处理 Python pydub
    • Python使用pydub模块转换音频格式以及对音频进行剪辑
      前言 近端时间看了一个短视频,觉得视频的背景音乐片段很不错,想把这个背景音乐得到,虽然小编运用Python爬虫肯定能得到这首音乐,但是这个音乐片段肯定是得不到的,于是网上看一下相关官方文档,没想到python真的有模...
      99+
      2022-06-02
      python转换音频格式 python pydub 混音 python音频处理
    • 怎么在Python中使用pydub模块转换音频格式
      这篇文章将为大家详细讲解有关怎么在Python中使用pydub模块转换音频格式,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。1.需要下载的Python模块和ffmpeg多媒体处理工具需要的P...
      99+
      2023-06-15
    • Linux下如何使用SoundConverter处理音频
      这篇文章将为大家详细讲解有关Linux下如何使用SoundConverter处理音频,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。SoundConverter 是一款批量音频格式转换工具,只需要拖放即可,...
      99+
      2023-06-27
    • 如何利用python处理原始音频数据
      目录一、基础知识二、转换函数三、片段特征函数四、片段操作一、基础知识 PCM(pulse code modulation) ,即脉冲编码调制,是将模拟信号转为数字信号的一种编码系统。...
      99+
      2022-11-12
    • 如何使用Python的OpenCV库处理图像和视频
      目录介绍计算机视觉OpenCV应用:安装使用 OpenCV 处理图像1. 从文件中读取图像2. 调整图像大小:3. 旋转图像4. 翻转图像:5. 重写图像6. 裁剪图像7. 绘制形状...
      99+
      2022-11-11
    • 如何使用Octave数学技术处理音频文件
      小编给大家分享一下如何使用Octave数学技术处理音频文件,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!我们的数字音频处理技术第三部分涵盖了信号调制内容,将解释如...
      99+
      2023-06-27
    • 怎么利用python处理原始音频数据
      本篇内容介绍了“怎么利用python处理原始音频数据”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!一、基础知识PCM(pulse code ...
      99+
      2023-06-22
    • 如何使用 JavaScript object URLs进行图像音频和视频的处理
      本篇文章为大家展示了如何使用 JavaScript object URLs进行图像音频和视频的处理,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。许多Web应用程序需...
      99+
      2022-10-19
    • PHP中如何进行智能音乐和音频处理?
      随着音乐产业的不断发展和普及,音乐制作和音频处理的需求也日益增多。而PHP作为一种高度可扩展的编程语言,已经不仅仅局限于Web开发领域,还能用于音乐和音频的处理。本文将介绍如何使用PHP进行智能音乐和音频处理。一、智能音乐处理智能音乐处理是...
      99+
      2023-05-22
      PHP 音频处理 智能音乐
    • iOS使用音频处理框架The Amazing Audio Engine实现音频录制播放
      iOS 第三方音频框架The Amazing Audio Engine使用,实现音频录制、播放,可设置配乐。 首先看一下效果图: 下面贴上核心控制器代码: #import "V...
      99+
      2022-05-27
      iOS 音频
    • python音频处理用到的操作的示例代码
      前言 本文主要记录python下音频常用的操作,以.wav格式文件为例。其实网上有很多现成的音频工具包,如果仅仅调用,工具包是更方便的。 更多pyton下的操作可以参考: 用python做科学计算 1、批量...
      99+
      2022-06-05
      示例 音频处理 操作
    • realtek高清晰音频管理器如何使用
      这篇文章主要介绍“realtek高清晰音频管理器如何使用”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“realtek高清晰音频管理器如何使用”文章能帮助大家解决问题。realtek高清晰音频管理器使...
      99+
      2023-07-01
    • 如何使用Python下载抖音无水印视频
      这篇文章主要介绍如何使用Python下载抖音无水印视频,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!一、获取抖音视频连接得到如下信息: “5.1 HV:/ 守门员戴手套没法系鞋带这种体育精神,值得尊敬%遇见足球 %足...
      99+
      2023-06-15
    • 如何使用phonegap播放音频
      小编给大家分享一下如何使用phonegap播放音频,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!实例如下:<!DOCTYP...
      99+
      2022-10-19
    • 如何使用HTML5音频元素
      本篇内容主要讲解“如何使用HTML5音频元素”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“如何使用HTML5音频元素”吧! x新引入的HTML5<aud...
      99+
      2022-10-19
    • 如何使用FFmpeg视频处理
      这篇文章给大家分享的是有关如何使用FFmpeg视频处理的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。FFmpeg 是视频处理最常用的开源软件。它功能强大,用途广泛,大量用于视频网站和商业软件(比如 Youtube...
      99+
      2023-06-26
    • 如何使用使用python+opencv解析视频并处理视频中的水印
      本篇内容主要讲解“如何使用使用python+opencv解析视频并处理视频中的水印”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“如何使用使用python+opencv解析视频并处理视频中的水印”...
      99+
      2023-06-02
    软考高级职称资格查询
    编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
    • 官方手机版

    • 微信公众号

    • 商务合作