import pyaudio import wave # Initialize PyAudio p = pyaudio.PyAudio() # List available input devices print("Available audio input devices:") for i in range(p.get_device_count()): device_info = p.get_device_info_by_index(i) if device_info['maxInputChannels'] > 0: print(f"Device ID {i}: {device_info['name']} (Max channels: {device_info['maxInputChannels']})") # Prompt user to select a device device_index = int(input("Please select the device ID to use for recording: ")) n_channels = int(input("Please enter the number of channels to use for recording: ")) duration_sec = int(input("Please enter the desired duration (in seconds) of the recording: ")) # Parameters CHANNELS = n_channels # Number of channels SAMPLE_RATE = 48000 CHUNK = 32 # Number of frames per buffer FORMAT = pyaudio.paInt16 # 16-bit audio RECORD_SECONDS = duration_sec # Duration to record (in seconds) OUTPUT_FILENAME = "output.wav" MONITORING = True # To write to a text file as long as the device is recording # Get the chosen device's info to validate it can support the entered number of channels and 48kHz device_info = p.get_device_info_by_index(device_index) max_channels = device_info['maxInputChannels'] if max_channels < CHANNELS: print(f"Error: The selected device only supports {max_channels} channels, but {CHANNELS} channels are required.") p.terminate() exit(1) # Open stream stream = p.open(format=FORMAT, channels=CHANNELS, rate=SAMPLE_RATE, input=True, input_device_index=device_index, frames_per_buffer=CHUNK) print(f"Recording {RECORD_SECONDS} seconds of audio from device ID {device_index}...") frames = [] print (f"Check status {stream.is_active()}") if MONITORING: open("current_recording.txt","w+") for i in range(int(SAMPLE_RATE / CHUNK * RECORD_SECONDS)): print (i, f"RECORDING: Check status {stream.is_active()}") # This line is for testing try: # Record audio # data = stream.read(CHUNK) data = stream.read(CHUNK, exception_on_overflow = False) # This line (as an alternative to the line above) is to prevent overflows from terminating the recording frames.append(data) if MONITORING: if i%int(10*SAMPLE_RATE/CHUNK) == 0: # Writing current time into "current_recording.txt" every 10 seconds current_second = int(i*CHUNK/SAMPLE_RATE) with open('current_recording.txt', 'a') as f: f.write(f"{current_second}\n") except: print ("Error") print("Finished recording.") print (f"Check status {stream.is_active()}") # Stop and close the stream stream.stop_stream() stream.close() # Terminate PyAudio p.terminate() # Save the recorded audio to a file wf = wave.open(OUTPUT_FILENAME, 'wb') wf.setnchannels(CHANNELS) wf.setsampwidth(p.get_sample_size(FORMAT)) wf.setframerate(SAMPLE_RATE) wf.writeframes(b''.join(frames)) wf.close() print(f"Audio saved to {OUTPUT_FILENAME}.")