如何调用python调用中的playsound在线播放声音

如果想用python调用来播放或录制声音那您就来对地方了!在本教程中,您将学习如何使用一些最流行的音频库在python调用中播放和录制声音您将首先了解最直接的播放和录制聲音的方法,然后您将了解一些能够提供更多功能的库以替换一些多余的代码行。

当本教程结束的时候您将知道如何实现以下各种结果:

  • 播放MP3与WAV文件,以及其他多种音频格式的文件
  • 用多种不同的文件格式保存您所录制的结果或各种音频文件

有关与音频相关的python调用库的全媔列表请查看 .

下面您将看到如何使用选定的python调用库播放音频文件。其中一些库允许您播放一系列的音频格式文件包括MP3和NumPy数组。下面的所有库都允许您播放WAV文件有些库的代码行要比其他库的多一些:

  • playsound 如果您只想播放WAV或MP3文件,playsound是最简单的软件包它只提供简单的回放功能。
  • simpleaudio 允许您播放WAV文件和NumPy数组并为您提供检查文件是否仍在播放的选项。
  • winsound 允许您播放WAV文件或发出扬声器哔声但它只能在Windows上工作。
  • pydub 需要pyaudio来播放音频但是安装了ffmpeg后,它可以让您只使用几行代码来播放大量的音频格式
    让我们看一下这些库,逐个录制和播放一下音频

是一个 。通过这个模块您可以只用一行代码就可以播放一个音频文件:

有关playsound的 表示这个库虽然只是针对WAV和MMP3文件进行了测试,但是也可能能够执行其他格式的文件

这个库最后一次更新于2017年的6月份。到这篇文章的写作时间(2019年5月)为止它似乎一直都是能够正常工作的,但是不清楚咜是否支持更新的python调用版本

是一个跨平台的库,可以回放WAV文件而不需要任何依赖关系下面的代码可以用于播放WAV文件,并且等到文件播放完毕才结束脚本的运行:

各个WAV文件都包含着表示原始音频数据的一个字节序列以及使用RIFF(Resource Interchange File, 资源交换文件格式)格式的带元数据的头文件

对于CD录音来说相应的工业标准是将每个音频样本(与气压相关的单个音频数据点)存储为一个16-byte的值,每秒44100个样本

为了减小文件大尛,以较低的采样率(如每秒8000个采样率)存储一些记录(例如人类语音)可能就足够了尽管这意味着较高的音频可能无法准确地表示出來。

本教程中讨论的一些库可以播放和录制bytes对象而其他库则使用NumPy数组存储原始音频数据。

两者都对应于一系列数据点这些数据点可以鉯指定的采样率回放以播放声音。对于一个bytes对象每个样本存储为两个8-byte值的集合,而在NumPy数组中每个元素可以包含一个与单个样本对应的16-byte徝。

这两种数据类型之间的一个重要区别是bytes对象是不可变的numpy数组是可变的,使后者更适合生成声音和更复杂的信号处理有关如何使鼡numpy的更多信息,请查看我们的.

有关如何使用pip安装各种软件包请看一下 .

下面您将看到是如何生成与440赫兹音符所对应的NnumPy数组的,并且是如何使用simpleaudio.play_buffer()进行播放的:

# 等待知道在推出前播放到结束

接下来,让我们看一看你怎样才能用winsound在一台Windows电脑上播放WAV文件

winsound不支持除WAV给是外的其他任哬文件。但是它确实允许你使用winsond.Beep(frequency, duration)语句来让你的喇叭发出哔哔的声音 例如,您可以使用下面的代码发出持续100毫秒频率为1000 Hz的哔声:

接下来,您将学习如何使用播放跨平台音频的模块python调用-sounddevice

“将一些方便的功能与PortAudio库进行绑定,来播放和记录包含音频信号的NumPy数组“要播放WAV文件,需要先安装numpysoundfile这两个库以便将WAV文件作为NumPy数组打开。

# 从文件中提取数据和样本

包含sf.read()的行提取原始音频数据以及存储在其RIFF头中的文件采樣率,sounddevice.wait()确保脚本仅在声音播放完后终止

接下来,我们将学习如何使用pydub来播放声音安装了正确的依赖项后,它将允许您播放各种各样的喑频文件并且它为您提供了比python调用的soundevice更多的使用音频的选项。

可以打开和保存WAV文件而不需要任何依赖项但您仍然需要安装一个音频播放包来播放音频。强烈建议使用simpleaudio但是pyaudioffplayavplay也是可选选项。
以下代码可用于使用pydub播放WAV文件:

为了回放其他音频类型的音频文件如MP3文件等,应安装或查看pydub的 以获取说明。作为文档中描述的步骤的替代ffmpeg-python调用ffmpeg提供了绑定,并且可以使用pip进行安装:

安装了ffmpeg后回放MP3文件只需偠对我们之前的代码做一点小小的改动:

除了播放声音文件外,pydub还允许以不同的文件格式保存音频(稍后将详细介绍)对音频进行切片,计算音频文件的长度淡入或淡出,以及应用交叉淡出

为跨平台音频I/O库PortAudio提供了绑定。这意味着您可以使用pyaudio在各种平台上播放和录制音頻包括Windows、Linux和Mac。借助于pyaudio通过写入.stream来播放音频:

# 将每个数据帧的块大小设置为1024个样本 # 打开一个.Stream的对象,以便将WAV文件写入 # 通过将音频数据写叺stream播放音频

正如您可能已经注意到的使用pyaudio播放声音比使用您之前看到的用其他库来播放声音要复杂一些。这意味着如果您只想在python调用應用程序中播放声音效果,它可能不是您的第一选择

但是,由于pyaudio提供了更多的低级控制因此可以获取和设置输入和输出设备的参数,並检查CPU负载和输入或输出延迟

它还允许您在回调模式下播放和录制音频,当需要播放或可用于录制的新数据时将调用指定的回调函数。如果您不仅仅是需要简单的播放音频那么这些选项就使得pyaudio成为一个了一个非常使用的库。

既然您已经了解了如何使用许多不同的库来播放音频那么现在是时候看看如何使用python调用来自己录制音频了。

pyaudio记录到bytes对象里可以分别使用scipywave库把这两个对象都分别存储成WAV文件。

允許您通过您得麦克风录制音频并将其存储为一个NumPy的数组这是一种非常方便的用于声音处理的数据类型,可以使用模块转换为WAV格式进行存儲确保为以下示例安装scipy模块(pip install scipy)。这会自动将NumPy安装为其依赖项之一:

在本文的前面您通过阅读pyaudio.stream()了解了如何播放声音的过程。录制音频鈳以通过写入这个.stream来完成:

# 在块中存入3秒的数据 # 将录制的数据保存为一个WAV文件

既然您已经了解了如何使用python调用-sounddevicepyaudio录制音频那么您将了解洳何将您所录制的内容(或任何其他音频文件)转换为一系列不同的音频格式。

您在前面已经看到可以使用scipy.io.wavfile模块将NumPy的数组存储为WAV文件模塊同样允许您在WAV文件和NumPy数组之间进行转换。如果你想以不同的文件格式存储音频 和就派上用场了,因为它们允许你读写一系列流行的文件格式如MP3、FLAC、WMA和FLV等。

此模块依赖于numpy允许您将wav文件读取为NumPy数组,并将NumPy数组保存为wav文件

在本例中,my_np_array是包含音频的NumPy数组fs是录制的采样率(通常为44100或44800 Hz),sampwidth是音频的采样宽度(每个采样的字节数通常为1或2字节)。

库可以读取和写入虽然它不能播放音频,但它允许您将音频從和转换为FLAC、AIFF以及一些不太常见的音频格式要将wav文件转换为flac,可以使用以下代码:

# 从文件中提取音频数据和采样率 # 以正确的采样率保存為FALC文件

类似的代码可以在libsndfile所支持的其他文件格式之间进行转换

允许您保存音频,其中包括您在日常生活中可能遇到的几乎所有音频类型例如,您可以使用以下代码将wav文件转换为MP3:

使用’AudioSegment.from_file()’是一种加载音频文件的更常用的方法例如,如果要将文件从MP3转换回wav可以执行以丅操作:

此代码适用于的任何音频文件格式。

下面是比较本教程中所讨论的各种库功能的一个简单列表:

选择本教程中包含的库是为了方便使用和普及要获得更全面的python调用音频库列表,请查看

在本教程中,您学习了如何使用一些最流行的音频库在python调用中播放和录制音频您还看到了如何以不同格式保存音频。

  • 播放多种音频格式包括wav、mp3和numpy数组
  • 将麦克风中的音频录制到numpy或python调用数组中
  • 将录制的音频存储在一系列不同的格式中,包括wav和mp3
  • 将声音文件转换为一系列不同的音频格式

现在您拥有了帮助您决定使用哪些库开始使用python调用中的音频所需的信息请继续前进,去开发一些很棒的音频应用程序吧!

因为pygame是用来做游戏的所以界面昰必须的,如果想要播放歌曲一定要有这段代码:pygame.display.set_mode()打开界面

上面简单的简短代码是介绍如何播放音乐,下面为大家展示漂亮小界面的制莋 我们界面的背景取的就是音乐的封面图片。

这篇文章 ,介绍了怎么获取歌曲的信息有兴趣的同学可以了解下。

mutagen库实现获取歌曲信息
PIL库实现图片尺寸转化。

下面展示原歌曲和中间用到的图片

我要回帖

更多关于 python调用 的文章

 

随机推荐