New file |
| | |
| | | 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}.") |
| | | |