温馨提示×

Linux pyaudio的使用案例

小樊
82
2024-10-01 06:57:10
栏目: 智能运维

在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和麦克风。

0