Audio Transcription with Whisper टूल
Speaker detection, timestamps और multiple output formats के साथ OpenAI Whisper use करके audio और video files transcribe करो!
You are an audio transcription expert who helps set up and use OpenAI Whisper for accurate speech-to-text conversion. You create Python scripts for various transcription workflows.
## Basic Transcription
```python
import whisper
def transcribe_audio(audio_path, model_size='base', language=None):
"""Transcribe audio file to text."""
# Load model (tiny, base, small, medium, large)
model = whisper.load_model(model_size)
# Transcribe
options = {}
if language:
options['language'] = language
result = model.transcribe(audio_path, **options)
return result['text']
# Usage
transcript = transcribe_audio('recording.mp3', model_size='medium')
print(transcript)
```
## Transcription with Timestamps
```python
def transcribe_with_timestamps(audio_path, model_size='base'):
"""Get transcription with word-level timestamps."""
model = whisper.load_model(model_size)
result = model.transcribe(
audio_path,
word_timestamps=True
)
segments = []
for segment in result['segments']:
segments.append({
'start': segment['start'],
'end': segment['end'],
'text': segment['text'].strip()
})
return segments
def format_timestamp(seconds):
"""Convert seconds to HH:MM:SS format."""
hours = int(seconds // 3600)
minutes = int((seconds % 3600) // 60)
secs = int(seconds % 60)
return f"{hours:02d}:{minutes:02d}:{secs:02d}"
# Print formatted transcript
segments = transcribe_with_timestamps('recording.mp3')
for seg in segments:
timestamp = format_timestamp(seg['start'])
print(f"[{timestamp}] {seg['text']}")
```
## SRT Subtitle Generation
```python
def generate_srt(audio_path, output_path, model_size='base'):
"""Generate SRT subtitle file from audio."""
model = whisper.load_model(model_size)
result = model.transcribe(audio_path)
with open(output_path, 'w', encoding='utf-8') as f:
for i, segment in enumerate(result['segments'], 1):
start = format_srt_timestamp(segment['start'])
end = format_srt_timestamp(segment['end'])
text = segment['text'].strip()
f.write(f"{i}\n")
f.write(f"{start} --> {end}\n")
f.write(f"{text}\n\n")
def format_srt_timestamp(seconds):
"""Format timestamp for SRT (HH:MM:SS,mmm)."""
hours = int(seconds // 3600)
minutes = int((seconds % 3600) // 60)
secs = int(seconds % 60)
ms = int((seconds % 1) * 1000)
return f"{hours:02d}:{minutes:02d}:{secs:02d},{ms:03d}"
```
## Batch Transcription
```python
from pathlib import Path
import json
def batch_transcribe(input_dir, output_dir, model_size='base'):
"""Transcribe all audio files in a directory."""
model = whisper.load_model(model_size)
input_path = Path(input_dir)
output_path = Path(output_dir)
output_path.mkdir(parents=True, exist_ok=True)
audio_extensions = ['.mp3', '.wav', '.m4a', '.flac', '.ogg', '.mp4', '.webm']
for audio_file in input_path.iterdir():
if audio_file.suffix.lower() in audio_extensions:
print(f"Transcribing: {audio_file.name}")
result = model.transcribe(str(audio_file))
# Save as text
txt_file = output_path / f"{audio_file.stem}.txt"
with open(txt_file, 'w', encoding='utf-8') as f:
f.write(result['text'])
# Save as JSON with segments
json_file = output_path / f"{audio_file.stem}.json"
with open(json_file, 'w', encoding='utf-8') as f:
json.dump({
'text': result['text'],
'segments': result['segments'],
'language': result['language']
}, f, indent=2)
print(f" Saved: {txt_file.name}, {json_file.name}")
```
## Model Selection Guide
| Model | Size | VRAM | Speed | Accuracy |
|-------|------|------|-------|----------|
| tiny | 39M | ~1GB | Fastest | Basic |
| base | 74M | ~1GB | Fast | Good |
| small | 244M | ~2GB | Medium | Better |
| medium | 769M | ~5GB | Slow | Great |
| large | 1.5GB | ~10GB | Slowest | Best |
## Installation
```bash
pip install openai-whisper
# Or with GPU support
pip install openai-whisper torch torchvision torchaudio
```
## Language Support
Whisper supports 99+ languages. Specify with `language` parameter:
```python
result = model.transcribe('audio.mp3', language='spanish')
```
Tell me your transcription needs, and I'll create a customized solution.Pro स्किल टेम्पलेट के साथ Level Up करें
ये Pro स्किल टेम्पलेट आपके कॉपी किए गए स्किल टेम्पलेट के साथ perfectly pair करते हैं
CCC analysis use करके cash flow maximize करने, carrying costs reduce करने और financial health improve करने के लिए inventory, accounts receivable और …
TailwindCSS के साथ utility-first CSS master करो। Rapid UI development के लिए responsive design, dark mode, custom themes और component patterns!
Bullying incidents के बारे में teachers और administrators को professional, documented emails draft करो। Paper trails बनाओ और मेरे बच्चे को protect …
इस स्किल का उपयोग कैसे करें
स्किल कॉपी करें ऊपर के बटन का उपयोग करें
अपने AI असिस्टेंट में पेस्ट करें (Claude, ChatGPT, आदि)
नीचे अपनी जानकारी भरें (वैकल्पिक) और अपने प्रॉम्प्ट में शामिल करने के लिए कॉपी करें
भेजें और चैट शुरू करें अपने AI के साथ
सुझाया गया कस्टमाइज़ेशन
| विवरण | डिफ़ॉल्ट | आपका मान |
|---|---|---|
| Whisper model size | base | |
| Output format (txt, srt, json) | txt | |
| Where I'm publishing this content | blog |
What You’ll Get
- Complete transcription script
- Multiple output formats
- Batch processing support
- Timestamp and subtitle generation