Transcribe audio/video files to SRT subtitles in one command. Optimized for large files, long movies, and video editing workflows.
# 1. Try it instantly (no install needed)
npx @illyism/transcribe video.mp4
# 2. Set your OpenAI API key (one-time setup)
export OPENAI_API_KEY=sk-...
# 3. Transcribe anything
npx @illyism/transcribe video.mp4
npx @illyism/transcribe https://www.youtube.com/watch?v=VIDEO_IDThat's it! Get your free API key here and start transcribing.
While OpenAI's Whisper has multiple ways to use it, this tool provides a simpler, more convenient experience:
| Feature | @illyism/transcribe | Official Whisper CLI | Local Whisper (whisper.cpp) |
|---|---|---|---|
| Setup | Zero setup with npx/bunx |
Install Python package | Download models (~1-5GB) |
| Video Support | β Automatic with FFmpeg | β Audio only | β Audio only |
| YouTube Support | β Built-in | β Manual download | β Manual download |
| SRT Output | β Built-in | β Manual formatting | β Available |
| Processing | βοΈ Cloud (fast) | βοΈ Cloud (fast) | π» Local (slower) |
| Cost | $0.006/min | $0.006/min | Free (after setup) |
| Internet Required | β Yes | β Yes | β No |
| Best For | Quick tasks, videos, YouTube | API integration | Privacy, offline use |
- π¬ Handles videos directly - No need to manually extract audio
- π₯ YouTube support - Transcribe YouTube videos with just the URL
- π SRT format ready - Generates subtitles automatically
- π Zero installation - Just run
npx @illyism/transcribe video.mp4 - π§ Simple config - One-time API key setup
- π Cross-platform - Works on macOS, Linux, Windows
Perfect for: Content creators, podcasters, and developers who need quick, accurate transcriptions with minimal setup.
Got a 30-60 minute video that's 2-4GB? Other tools like Descript upload the entire video file, which takes forever and costs more.
This tool:
- π¬ Extracts only the audio locally (takes seconds with FFmpeg)
- βοΈ Uploads only ~20-40MB of audio to Whisper
- π Generates SRT subtitles
Result: 10-100x faster than uploading multi-GB video files. Same quality, fraction of the time and bandwidth.
- π¬ Video & Audio Support: Works with MP4, MP3, WAV, M4A, WebM, OGG, MOV, AVI, and MKV
- π₯ YouTube Support: Download and transcribe YouTube videos directly
- π― High Accuracy: Powered by OpenAI's Whisper API
- β‘ Smart Optimization: Automatic 1.2x speed processing + mono/16kHz extraction (optimized for dialogue)
- π SRT Format: Generates standard SRT subtitle files with precise timestamps
- ποΈ Long Movies: Automatic chunking for feature-length content (45+ minutes)
- π¬ Editor-Friendly: Timecode offset, custom output paths, chunk size control
- π§ Simple Setup: Easy configuration via environment variable or config file
- π Multi-language: Automatically detects language
- π Lightning Fast: Optimized for 2-4GB+ video files
npx @illyism/transcribe video.mp4npm install -g @illyism/transcribe
# or: bun install -g @illyism/transcribeπ¦ Install FFmpeg (required)
# macOS
brew install ffmpeg
# Ubuntu/Debian
sudo apt-get install ffmpeg
# Windows
choco install ffmpegπ₯ Install yt-dlp (optional, for YouTube)
# macOS
brew install yt-dlp
# Ubuntu/Debian
sudo apt install yt-dlp
# Windows
winget install yt-dlp
# Or with pip
pip install yt-dlpπ Get OpenAI API Key (required)
- Go to platform.openai.com/api-keys
- Create a new API key
- Copy it and set it up below β¬οΈ
One-time setup - Choose your preferred method:
mkdir -p ~/.transcribe && echo '{"apiKey": "sk-YOUR_KEY"}' > ~/.transcribe/config.jsonexport OPENAI_API_KEY=sk-YOUR_KEYDon't have a key? Get one free here (takes 1 minute)
# Local video file
transcribe video.mp4
# YouTube video
transcribe https://www.youtube.com/watch?v=VIDEO_ID
# Audio file
transcribe podcast.mp3
# Disable optimization (use original audio)
transcribe video.mp4 --rawOutputs: Creates video.srt in the same directory.
Perfect for video editing workflows:
# Custom output path (file or directory)
transcribe movie.mkv --output ./subtitles
transcribe movie.mkv --output ./subtitles/movie.srt
# Timecode offset (for editorial timelines)
transcribe movie.mkv --offset 01:00:00.000 # Start at 1 hour
transcribe movie.mkv --offset 3600 # Same, in seconds
# Force chunking for very long movies
transcribe long_movie.mkv --chunk-minutes 15Why chunking? Movies 45+ minutes are automatically split into ~20-minute chunks for reliability. Each chunk is transcribed separately, then merged seamlessly with correct timestamps.
By default, the tool optimizes large files:
2.7GB video β Extract audio (mono, 16kHz) β Speed up 1.2x β Chunk if >45min β Upload chunks β Transcribe β Merge & adjust timestamps
For long movies (45+ minutes):
- Automatically splits into ~20-minute chunks
- Transcribes each chunk separately
- Merges results with correct timestamps
- Handles 2+ hour movies reliably
Result:
- β‘ 99.5% smaller uploads (2.7GB β 12.8MB)
- π 10-100x faster than uploading full video
- π― ~98% accuracy maintained
- π° Same cost ($0.006/min)
Want original audio? Add --raw flag.
npm install @illyism/transcribeimport { transcribe } from '@illyism/transcribe'
const result = await transcribe({
inputPath: 'video.mp4',
apiKey: process.env.OPENAI_API_KEY,
optimize: true // default, set false to disable
})
console.log(result.srtPath) // Path to generated SRT file
console.log(result.text) // Full transcription textFull API reference
interface TranscribeOptions {
inputPath: string // Path to video/audio file
apiKey?: string // OpenAI API key (or use env var)
outputPath?: string // Custom output path (optional)
optimize?: boolean // Enable optimization (default: true)
}
interface TranscribeResult {
srtPath: string // Path to generated SRT file
text: string // Full transcription text
language: string // Detected language
duration: number // Duration in seconds
}π Supported Formats
- Video: MP4, WebM, MOV, AVI, MKV
- Audio: MP3, WAV, M4A, OGG, Opus
- YouTube: All videos, Shorts, youtu.be links
π° Cost
OpenAI Whisper API: $0.006 per minute
Examples:
- 5 min: $0.03
- 30 min: $0.18
- 2 hours: $0.72
βοΈ How It Works
- Extract audio from video (mono, 16kHz - optimized for speech)
- Optimize: 1.2x speed + compression if >24MB
- Auto-chunk if >45 minutes (for reliability)
- Upload chunks to Whisper API (or single file)
- Generate SRT with timestamps
- Merge chunks (if needed) and adjust timestamps to match original
- Apply timecode offset (if specified)
- Clean up temp files
π SRT Output Example
1
00:00:00,000 --> 00:00:03,420
Hey and thank you for getting the SEO roast.
2
00:00:03,420 --> 00:00:06,840
I'll take a look at your website and see what things we can improve."OPENAI_API_KEY not found"
Set up your API key using one of the methods in API Key Setup.
"FFmpeg not found"
Install FFmpeg:
brew install ffmpeg # macOS
sudo apt install ffmpeg # Ubuntu
choco install ffmpeg # Windows"yt-dlp not found" (YouTube only)
Install yt-dlp:
brew install yt-dlp # macOS
sudo apt install yt-dlp # Ubuntu
pip install yt-dlp # Any platformFile not found error
Use absolute paths:
transcribe /full/path/to/video.mp4API errors (502, timeout, etc.)
OpenAI API may be temporarily down. Wait 30 seconds and try again.
"Could not parse multipart form" error
If you're using Bun runtime, switch to Node.js:
# Use Node.js instead of Bun
node dist/cli.js video.mp4
# Or install globally and use the transcribe command
npm install -g @illyism/transcribe
transcribe video.mp4The CLI works best with Node.js 18+ due to OpenAI SDK compatibility.
- π¦ NPM Package
- π GitHub Repo
- π Full Changelog
- π§ͺ A/B Test Results
- π Report Issues
Pull requests welcome! See GitHub repo.
MIT Β© Ilias Ismanalijev