使用的第三方库:

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,具体截图我将放下教程下方,或者大家可以自己进入函数内部看看就知道),以下是官方源码截图

python 下载无损音乐 python flac_python 下载无损音乐

python 下载无损音乐 python flac_采样率_02

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对象中所返回的值,具体参数可在调试的时候在相应位置打上断点进行查看,比如:

python 下载无损音乐 python flac_采样率_03

 哈哈,教程到这里就结束了,接下来老样子了,存在不足的地方欢迎大家评论或私信指出来,我也将不定期完善各个教程。