python如何录音_python实现录音功能(可随时停止录音)

本文实例为大家分享了python实现录音功能的具体代码,供大家参考,具体内容如下

# -*- coding: utf-8 -*-

import pyaudio

import time

import threading

import wave

class Recorder():

def __init__(self, chunk=1024, channels=1, rate=64000):

self.CHUNK = chunk

self.FORMAT = pyaudio.paInt16

self.CHANNELS = channels

self.RATE = rate

self._running = True

self._frames = []

def start(self):

threading._start_new_thread(self.__recording, ())

def __recording(self):

self._running = True

self._frames = []

p = pyaudio.PyAudio()

stream = p.open(format=self.FORMAT,

channels=self.CHANNELS,

rate=self.RATE,

input=True,

frames_per_buffer=self.CHUNK)

while(self._running):

data = stream.read(self.CHUNK)

self._frames.append(data)

stream.stop_stream()

stream.close()

p.terminate()

def stop(self):

self._running = False

def save(self, filename):

p = pyaudio.PyAudio()

if not filename.endswith(".wav"):

filename = filename + ".wav"

wf = wave.open(filename, 'wb')

wf.setnchannels(self.CHANNELS)

wf.setsampwidth(p.get_sample_size(self.FORMAT))

wf.setframerate(self.RATE)

wf.writeframes(b''.join(self._frames))

wf.close()

print("Saved")

if __name__ == "__main__":

for i in range(1,4):

a = int(input('请输入相应数字开始:'))

if a == 1:

rec = Recorder()

begin = time.time()

print("Start recording")

rec.start()

b = int(input('请输入相应数字停止:'))

if b == 2:

print("Stop recording")

rec.stop()

fina = time.time()

t = fina - begin

print('录音时间为%ds'%t)

rec.save("1_%d.wav"%i)

本人在尝试语音识别领域的研究,欢迎一起探讨。

更多精彩python学习专题欢迎点击学习:

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
实现基于Python的实时音频信号处理,可以使用PyAudio库。PyAudio是一个用于Python的音频处理库,它提供了一个接口来处理音频流的输入和输出。 以下是一个简单的实时音频处理的示例,其中包括播放声音和录制声音: ```python import pyaudio import numpy as np # 定义参数 CHUNK = 1024 RATE = 44100 # 初始化PyAudio p = pyaudio.PyAudio() # 打开音频流 (输入和输出) stream = p.open(format=pyaudio.paFloat32, channels=1, rate=RATE, input=True, output=True, frames_per_buffer=CHUNK) # 循环执行 while True: # 读取音频数据 data = stream.read(CHUNK) # 将音频数据转换为NumPy数组 data_np = np.frombuffer(data, dtype=np.float32) # 执行音频处理 processed_data = my_audio_processing_function(data_np) # 将处理后的数据写入音频流 stream.write(processed_data.tobytes()) # 关闭音频流 stream.stop_stream() stream.close() # 关闭PyAudio p.terminate() ``` 在上面的示例中,我们使用PyAudio打开了一个音频流,然后将输入和输出都打开了。然后我们进入了一个循环,在循环中读取音频数据,将其转换为NumPy数组,并执行一些音频处理。最后,我们将处理后的数据写入音频流。 要实现实时音频处理,我们需要将音频数据分成小块,每个块的大小为CHUNK,这样我们就可以在块之间执行处理。我们还可以通过修改RATE参数来控制音频流的采样率,这将影响我们可以处理的最高频率。 需要注意的是,上面的示例只提供了框架代码,实际的音频处理函数需要根据具体的需求进行编写。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值