一,python合成音乐
- import json
- import numpy as np
- import matplotlib.pyplot as plt
- from scipy.io.wavfile import write
-
- # 音阶频率对照表
- tone_freq_map={"#g3": 1863.7, "#b3": 2348.3, "e1": 329.5, "f2": 739.5, "d1": 293.4, "#c3": 1244.0,
- "#D": 155.46175, "E": 164.745, "E1": 82.3725, "#a1": 466.0, "d2": 621.8, "d3": 1318.0,
- "c3": 1174.1, "G1": 97.93175, "C": 130.75, "#C": 138.529625, "#d1": 310.9, "e3": 1479.3,
- "#b2": 1108.2, "c2": 554.1, "a1": 439.8, "D": 146.766875, "#F1": 92.44,"b1": 493.7,
- "#F": 184.881, "D1": 73.35075, "#a2": 987.2, "#G": 207.566,"b3": 2216.5, "g3": 1759.1,
- "#D1": 77.730875, "F1": 87.276, "#c2": 587.1, "B": 246.790625, "#C1": 69.232125,
- "#f1": 369.8, "#a3": 2092.0, "#d2": 659.0, "#g2": 879.7, "#f2": 783.7, "#b1": 523.0,
- "#f3": 1660.5, "#g1": 415.0, "f3": 1567.2, "#c1": 276.9, "C1": 65.375, "A": 219.922,
- "#A1": 116.49825, "A1": 109.9608, "g2": 830.3, "F": 174.5513, "f1": 349.1, "#A": 232.9965,
- "c1": 261.5, "a2": 932.0, "a3": 1974.6, "#d3": 1396.1, "#G1": 103.750125, "g1": 391.7,
- "G": 195.928875, "B1": 123.428, "b2": 1046.0, "e2": 698.2}
-
-
- def synthesizer(freq,duration,amp=1.0,sampling_freq=44100):
- ''' 合成音调 '''
- t=np.linspace(0,duration,duration*sampling_freq) # 创建时间轴
- audio=amp*np.sin(2*np.pi*freq*t)
- audio=audio.astype(np.int16)
- return audio
-
-
- if __name__=='__main__':
- lengths=60
-
- # 生成2秒的G调
- #input_tone='G'
- #duration=12 # 单位:秒
- amplitude=10000
- sampling_freq=44100 # 单位:Hz
-
- # 音阶及持续时间
- #tone_seq=[('D',0.3),('G',0.6),('C',0.5),('A',0.3),('#A',0.7)]
- tone_seq=[]
- keyss=list(tone_freq_map.keys())
- keys=[]
- ind=0
- for i in range(lengths):
- try:
- keys.append(keyss[ind])
- except IndexError:
- ind=0
- keys.append(keyss[ind])
- ind+=1
-
- for i in range(lengths):
- d=np.random.choice(keys[i:i+3])
- pl=np.random.randint(2,8)/10
- tone_seq.append((d,pl))
- output=np.array([])
- for i in tone_seq:
- input_tone=i[0]
- duration=i[1]
-
- # 生成音阶
- synthesized_tone=synthesizer(tone_freq_map[input_tone],duration,
- amplitude,sampling_freq)
- output=np.append(output,synthesized_tone,axis=0)
-
- # 将生成信号写入输出文件
- write('output_tone.wav',sampling_freq,output)
- print('生成文件: output_tone.wav 成功!')
执行结果如下:
生成文件: output_tone.wav 成功!
二, 播放音乐:
使用 pygame 模块播放
进入命令行安装 pygame: pip install pygame
- import pygame
-
- """
- pygame -- 音乐 常用方法
- pygame.init() 进行全部模块的初始化,
- pygame.mixer.init() 或者只初始化音频部分
- pygame.mixer.music.load('xx.mp3') 使用文件名作为参数载入音乐 ,音乐可以是ogg、mp3等格式。载入的音乐不会全部放到内容中,而是以流的形式播放的,即在播放的时候才会一点点从文件中读取。
- pygame.mixer.music.play()播放载入的音乐。该函数立即返回,音乐播放在后台进行。
- play方法还可以使用两个参数
- pygame.mixer.music.play(loops=0, start=0.0) loops和start分别代表重复的次数和开始播放的位置。
- pygame.mixer.music.stop() 停止播放,
- pygame.mixer.music.pause() 暂停播放。
- pygame.mixer.music.unpause() 取消暂停。
- pygame.mixer.music.fadeout(time) 用来进行淡出,在time毫秒的时间内音量由初始值渐变为0,最后停止播放。
- pygame.mixer.music.set_volume(value) 来设置播放的音量,音量value的范围为0.0到1.0。
- pygame.mixer.music.get_busy() 判断是否在播放音乐,返回1为正在播放。
- pygame.mixer.music.set_endevent(pygame.USEREVENT + 1) 在音乐播放完成时,用事件的方式通知用户程序,
- 设置当音乐播放完成时发送pygame.USEREVENT+1事件给用户程序。 pygame.mixer.music.queue(filename) 使用指定下一个要播放的音乐文件,
- 当前的音乐播放完成后自动开始播放指定的下一个。一次只能指定一个等待播放的音乐文件。
- """
-
- # 初始化
- pygame.mixer.init()
- # 加载音乐
- pygame.mixer.music.load('道德经.mp3'.encode())
- # 开始播放
- pygame.mixer.music.play()
- # 停止播放
- # pygame.mixer.music.stop()
-
-