基于Widora&Openwrt--NetRouter应用教程之声音与网络
-
回顾教程编写之初,是为了看懂目前许多开源应用,比如目前百度dueros,或是国内respeaker等语音开源项目都是基于python编写。那么今天进入正题,如何用python录音以及播放wav格式音频。
查找声卡:
root@ubuntu:/mnt# cat NetRouterPythonVoce/getinfo.py
import pyaudio
p = pyaudio.PyAudio()
for i in range(p.get_device_count()):
dev = p.get_device_info_by_index(i)
print((i,dev['name'],dev['maxInputChannels']))录音:
root@ubuntu:/mnt# cat NetRouterRecord.py
#coding=utf-8from pyaudio import PyAudio,paInt16
from datetime import datetime
import wave#define of params
NUM_SAMPLES = 2000
framerate = 16000
channels = 1
sampwidth = 2
#record time
TIME = 10def save_wave_file(filename, data):
'''save the date to the wav file'''
wf = wave.open(filename, 'wb')
wf.setnchannels(channels)
wf.setsampwidth(sampwidth)
wf.setframerate(framerate)
wf.writeframes("".join(data))
wf.close()def record_wave():
#open the input of wave
pa = PyAudio()
stream = pa.open(format = paInt16, channels = 1,
rate = framerate, input = True,
frames_per_buffer = NUM_SAMPLES)
save_buffer = []
count = 0
while count < TIME*4:
#read NUM_SAMPLES sampling data
string_audio_data = stream.read(NUM_SAMPLES)
save_buffer.append(string_audio_data)
count += 1
print '.'filename = datetime.now().strftime("%Y-%m-%d_%H_%M_%S")+".wav" save_wave_file(filename, save_buffer) save_buffer = [] print filename, "saved"
def main():
record_wave()if name == "main":
main()播放:
root@ubuntu:/mnt# cat NetRouterPythonVoce/play_wav.py
"""PyAudio Example: Play a WAVE file."""import pyaudio
import wave
import sysCHUNK = 1024
if len(sys.argv) < 2:
print("Plays a wave file.\n\nUsage: %s filename.wav" % sys.argv[0])
sys.exit(-1)wf = wave.open(sys.argv[1], 'rb')
p = pyaudio.PyAudio()
stream = p.open(format=p.get_format_from_width(wf.getsampwidth()),
channels=wf.getnchannels(),
rate=wf.getframerate(),
output=True)data = wf.readframes(CHUNK)
while data != '':
stream.write(data)
data = wf.readframes(CHUNK)stream.stop_stream()
stream.close()p.terminate()
- 列表
-
先上测试代码,注解稍后跟上~~~