Linux pyaudio的使用案例

avatar
作者
猴君
阅读量:0

在Linux系统中,pyaudio是一个用于处理音频流的Python库。以下是一些使用pyaudio的简单案例:

1. 播放音频文件

你可以使用pyaudiowave模块来播放WAV文件。以下是一个示例代码:

import pyaudio import wave  CHUNK = 1024 FORMAT = pyaudio.paInt16 CHANNELS = 1 RATE = 44100 RECORD_SECONDS = 5 WAVE_OUTPUT_FILENAME = "output.wav"  audio = pyaudio.PyAudio()  # 打开流 stream = audio.open(format=FORMAT,                     channels=CHANNELS,                     rate=RATE,                     input=False,                     frames_per_buffer=CHUNK)  # 写入WAV文件 wf = wave.open(WAVE_OUTPUT_FILENAME, 'wb') wf.setnchannels(CHANNELS) wf.setsampwidth(audio.get_sample_size(FORMAT)) wf.setframerate(RATE) wf.writeframes(b'Hello World!')  # 停止,关闭并释放资源 stream.stop_stream() stream.close() wf.close() audio.terminate() 

这段代码会播放一个5秒的"Hello World!"音频。

2. 从麦克风录音

以下是一个从麦克风录音并使用pyaudio保存为WAV文件的示例:

import pyaudio import wave  CHUNK = 1024 FORMAT = pyaudio.paInt16 CHANNELS = 1 RATE = 44100 RECORD_SECONDS = 5 WAVE_OUTPUT_FILENAME = "output.wav"  audio = pyaudio.PyAudio()  # 打开流 stream = audio.open(format=FORMAT,                     channels=CHANNELS,                     rate=RATE,                     input=True,                     frames_per_buffer=CHUNK)  # 写入WAV文件 wf = wave.open(WAVE_OUTPUT_FILENAME, 'wb') wf.setnchannels(CHANNELS) wf.setsampwidth(audio.get_sample_size(FORMAT)) wf.setframerate(RATE)  frames = []  # 读取数据 for i in range(0, int(RATE / CHUNK * RECORD_SECONDS)):     data = stream.read(CHUNK)     frames.append(data)  # 停止,关闭并释放资源 stream.stop_stream() stream.close() wf.close() audio.terminate() 

这段代码会录制5秒的麦克风音频并保存为"output.wav"。

注意:在运行这些代码之前,请确保你的系统已经安装了pyaudio库。如果没有安装,你可以使用pip来安装它:pip install pyaudio。另外,一些系统可能需要额外的依赖或配置才能使用pyaudio和麦克风。

广告一刻

为您即时展示最新活动产品广告消息,让您随时掌握产品活动新动态!