使用的第三方库:
pyaudio(播放音频帧)、mutagen(读取FLAC文件里的一些信息)、pydub(获取音频帧)
音频操作与FLAC文件相关知识参考文档:
废话不多说,先上代码再做解释,部分解释放在注释中:
import pyaudio
from mutagen.flac import FLAC
from pydub import AudioSegment
def get_music_time_length(file):
"""
除了重要部分,其他都不算太重要,其他的都是为后面项目的完整功能做的一个准备
:return:
"""
music_object = FLAC(file) # 重要
music_length = int(music_object.info.length)
minute = music_length // 60
second = music_length % 60
print(music_object)
print("声道数:"+str(music_object.info.channels)) # 重要部分
print("音频采样频率:"+str(music_object.info.sample_rate)) # 重要部分
print("音频采样大小:"+str(music_object.info.bits_per_sample)) # 重要部分
return str(minute) if minute > 10 else "0" + str(minute) + ":" + str(second)
def test(file, format, channels, rate):
"""
重要的函数,音频的播放基本都在这个函数中进行处理
"""
p = pyaudio.PyAudio()
song = AudioSegment.from_file(file)
"""
设置音频的参数:
format(采样大小与格式,因为我目前也是初步了解,但按照本教程的写法,format只能设置为2,因为pyaudio中只有1,2,3,4个模式,而能用来解析FLAC的只有2,具体截图我将放下教程下方,或者大家可以自己进入函数内部看看就知道),
channels(音频声道的数量,注意:此处一定要注意使用上面的函数打印的音频采样大小为24时,则将channels设置为2,如果音频采样大小为16,则将channels值设置为1,反正只能比最大声道数小,不能大,还有采样大小为16时设置为2,则没有声音【这让我一度怀疑,是不是下载了假的FLAC文件】,24设置为1时,只能听到部分,有兴趣的大家可以自己试试),
rate(设置音频采样率,照着上方函数获取的值填写就好了,当然采样率不同设置错了,也会导致播放出来的音频中的音调、节奏等都会发生改变,调试的时候我就出现过将女声变成男声,整个节奏慢半拍等状况,但有些歌将采样率调大了以后,反而是别有一番韵味,比如将:起风了【旧版】的采样率调制为48000)
"""
stream = p.open(format=format,
channels=channels,
rate=rate,
output=True)
# 读取音频帧并进行播放
for index in range(0, int(song.frame_count())):
stream.write(song.get_frame(index))
# 停止数据流
stream.stop_stream()
stream.close()
# 关闭 PyAudio
p.terminate()
if __name__ == '__main__':
music_list = ['CMJ - 萤火之森.flac','himmel - Carnation.flac',
'Christine Welch - 一百万个可能.flac','yihuik苡慧 - 麦浪.mp3',
'音阙诗听、锦零 - 空山新雨后.flac', '灰澈 - 星茶会.mp3']
for value in music_list:
# 懒得改了,就写死了这里
test('D:/MyPreject/snakeGame/data/music/flac/'+value, 2, 1, 44100)
注:这里重新注明一下,播放flac音频文件的话,还是推荐使用soundfile库读取后使用sounddevice进行播放,具体代码如下:
import soundfile as sf
import sounddevice as sd
data_array, sample_rate = sf.read(file)
sd.play(data_array, sample_rate)
sd.wait()
二次讲解与其他说明
设置音频的参数:
format:(采样大小与格式,因为我目前也是初步了解,但按照本教程的写法,format只能设置为2,因为pyaudio中只有1,2,3,4个模式,而能用来解析FLAC的只有2,具体截图我将放下教程下方,或者大家可以自己进入函数内部看看就知道),以下是官方源码截图
channels:(音频声道的数量,注意:此处一定要注意使用上面的函数打印的音频采样大小为24时,则将channels设置为2,如果音频采样大小为16,则将channels值设置为1,反正只能比最大声道数小,不能大,还有采样大小为16时设置为2,则没有声音【这让我一度怀疑,是不是下载了假的FLAC文件】,24设置为1时,只能听到部分,有兴趣的大家可以自己试试),
rate:(设置音频采样率,照着上方函数获取的值填写就好了,当然采样率不同设置错了,也会导致播放出来的音频中的音调、节奏等都会发生改变,调试的时候我就出现过将女声变成男声,整个节奏慢半拍等状况,但有些歌将采样率调大了以后,反而是别有一番韵味,比如将:起风了【旧版】的采样率调制为48000)
特别的注释信息:
""""
D:/MyPreject/snakeGame/data/music/CMJ - 萤火之森.flac
channels=2 # 声道数
bits_per_sample=24 # 采样大小
sample_rate = 48000 # 采样率
"""
"""
特别的版本
买辣椒也用券 - 起风了 (旧版).mp3, 2, 1, 48000
"""
注释信息中的参数为AudioSegment对象中所返回的值,具体参数可在调试的时候在相应位置打上断点进行查看,比如:
哈哈,教程到这里就结束了,接下来老样子了,存在不足的地方欢迎大家评论或私信指出来,我也将不定期完善各个教程。