阅读本文大概需要3.3分钟
播放音频文件
下面,您将看到如何使用所选的Python库来播放音频文件。其中一些库允
许您播放一系列音频格式,包括MP3和NumPy数组。
playsound:
如果您只想播放WAV或MP3文件,可以使用最简单的软件包。它只提供简单的回放功能。simpleaudio:
允许您播放WAV文件和NumPy数组,并为您提供检查文件是否仍在播放的选项。winsound:
允许您播放WAV文件或鸣响您的扬声器python-sounddevice
和pyaudio
为PortAudio库提供绑定,以便跨平台播放WAV文件。pydub
要求pyaudio
用于音频播放,但与ffmpeg
安装后,只需几行代码就可以播放大量的音频格式。
让我们逐一看看这些音频回放库。
playsound
playsound
是纯Python、跨平台、单功能模块,不依赖于播放声音。使用此模块,可以使用一行代码播放声音文件:
from playsound import playsound
playsound('myfile.wav')
playsound
声明它已经在WAV和MP3文件上进行了测试,但是它可能也适用于其他文件格式。
simpleaudio
simpleaudio
是一个跨平台库,用于播放没有依赖项的(单声道和立体声)WAV文件。以下代码可用于播放WAV文件,并在终止脚本之前等待该文件完成播放:
import simpleaudio as sa
filename = 'myfile.wav'
wave_obj = sa.WaveObject.from_wave_file(filename)
play_obj = wave_obj.play()
play_obj.wait_done() # 等到声音播放完毕
WAV文件包含位序列表示原始音频数据,以及带有元数据的标头采用RIFF(资源交换文件格式)格式。
下面,将看到如何生成与440 Hz音调相对应的NumPy数组,并使用simpleaudio.play_buffer()
:
import numpy as np
import simpleaudio as sa
frequency = 440 # 我们播放的音符是440赫兹
fs = 44100 # 每秒4100个样本
seconds = 3 # 注意持续时间为3秒
# *sample_rate步骤,范围在0到秒之间
t = np.linspace(0, seconds, seconds * fs, False)
# 产生一个440赫兹的正弦波
note = np.sin(frequency * t * 2 * np.pi)
# 确保最大值在16位范围内
audio = note * (2**15 - 1) / np.max(np.abs(note))
# 转换为16位数据
audio = audio.astype(np.int16)
# 开始播放
play_obj = sa.play_buffer(audio, 1, 2, fs)
# 等待播放结束后退出
play_obj.wait_done()
接下来,让我们看看如何使用winsound
上播放WAV文件,请执行以下操作。
winsound
可以使用内置的winsound
模块可以访问其基本的声音播放机器.只需几行代码即可播放WAV文件:
import winsound
filename = 'myfile.wav'
winsound.PlaySound(filename, winsound.SND_FILENAME)
winsound
不支持除WAV文件以外的任何文件的回放。但允许你用winsound.Beep(frequency, duration)
。例如,您可以使用以下代码发出1000 Hz的音调,持续100毫秒:
import winsound
winsound.Beep(1000, 100) #以1000赫兹的频率发出100毫秒的蜂鸣声
接下来,将学习如何使用python-sounddevice
跨平台音频回放模块。
python-sounddevice
带着python-sounddevice
, numpy
,和soundfile
安装后,现在可以将WAV文件读取为NumPy数组并回放:
import sounddevice as sd
import soundfile as sf
filename = 'myfile.wav'
# 从文件中提取数据和采样率
data, fs = sf.read(filename, dtype='float32')
sd.play(data, fs)
status = sd.wait() # 等待,直到文件完成播放
包含sf.read()
提取原始音频数据,以及存储在它的Rff头中的文件的采样率,以及sounddevice.wait()
确保脚本只在声音播放完毕后才终止。
接下来,我们将学习如何使用pydub
播放声音。它允许播放范围广泛的音频文件,并且提供了比使用音频更多的选项。
pydub
尽管pydub
可以在没有任何依赖项的情况下打开和保存WAV文件,但需要安装一个音频播放包来播放音频。
可以使用下列代码来播放WAV文件pydub
:
from pydub import AudioSegment
from pydub.playback import play
sound = AudioSegment.from_wav('myfile.wav')
play(sound)
为了播放其他音频类型,如MP3文件,应该安装ffmpeg
或libav
。并且可以使用pip安装:
$ pip install ffmpeg-python
带着ffmpeg
安装后,播放MP3文件只需要对我们以前的代码做一点小小的修改:
from pydub import AudioSegment
from pydub.playback import play
sound = AudioSegment.from_mp3('myfile.mp3')
play(sound)
使用AudioSegment.from_file(filename, filetype)
构造,可以播放任何类型的音频文件ffmpeg
。例如,您可以使用渐变来播放WMA文件:
sound = AudioSegment.from_file('myfile.wma', 'wma')
除了播放声音文件,pydub
允许您以不同的文件格式保存音频(稍后将详细介绍),切片音频,计算音频文件的长度,淡入或退出,并应用交叉衰减。