Spaces:
Running
Running
import gradio as gr | |
import whisper | |
import os | |
# Load the Whisper model | |
model = whisper.load_model("base") | |
def transcribe_audio(audio_file): | |
# Transcribe the audio | |
result = model.transcribe(audio_file.name) | |
# Get the base name of the file (without extension) for the output file | |
output_filename = os.path.splitext(os.path.basename(audio_file.name))[0] + ".txt" | |
# Save the transcript to a text file with the same name as the input file | |
with open(output_filename, "w") as text_file: | |
text_file.write(result["text"]) | |
return result["text"], output_filename | |
# Create Gradio interface | |
iface = gr.Interface( | |
fn=transcribe_audio, | |
inputs=gr.File(label="Upload Audio File"), | |
outputs=[ | |
gr.Textbox(label="Transcription"), | |
gr.File(label="Download Transcript") | |
], | |
title="Audio Transcription Tool", | |
description="Upload an audio file (WAV, MP3, etc.) to get its transcription. The transcript will be displayed and available for download." | |
) | |
# Launch the interface | |
iface.launch() |