Production-ready YouTube to MP3/MP4 converter.
PyPI: ytconvert-cli 1.0.1
Github: click here!
- Convert YouTube videos to MP3 (audio extraction)
- Download YouTube videos as MP4 (with quality selection)
- Batch download multiple URLs from a text file (with optional parallel downloads)
- Custom output directory support
- Progress indicators with download speed and ETA
- Clean error handling with specific exit codes
- FFmpeg is bundledβno separate install needed
- Uses yt-dlp Python API (no shell calls)
- Pip-installable and PyPI-ready
pip install ytconvert-cliFork https://github.com/Alkyones/ytconvert-cli
git clone https://github.com/Yourusername/ytconvert-cli
cd ytconvert-cli
pip install .# Convert to MP3 (default)
ytconvert https://www.youtube.com/watch?v=VIDEO_ID
# Convert to MP4
ytconvert https://www.youtube.com/watch?v=VIDEO_ID --format mp4
# MP4 with specific quality
ytconvert https://www.youtube.com/watch?v=VIDEO_ID --format mp4 --quality 720p
# Save to custom directory
ytconvert https://www.youtube.com/watch?v=VIDEO_ID -f mp3 -o ./downloads
# Get video info only (no download)
ytconvert https://www.youtube.com/watch?v=VIDEO_ID --info
# Search YouTube and download selected result (interactive)
ytconvert search "lofi hip hop"
# Search and download selected result as MP3
ytconvert search "chill beats" --audio
# Search and download selected result as MP4
ytconvert search "chill beats" --video
# Show help
ytconvert --help
# Show search command help
ytconvert search --helpShort options:
| Long | Short | Description |
|---|---|---|
| --format | -f | mp3 or mp4 |
| --quality | -q | Video quality |
| --output | -o | Output directory |
| --info | -i | Info only |
| --verbose | -v | Debug mode |
| --version | -V | Show version |
Search options:
| Long | Description |
|---|---|
| --limit | Number of search results (default: 10) |
| --audio | Download selected search result as MP3 |
| --video | Download selected search result as MP4 |
You can search YouTube directly in the terminal and choose what to download.
ytconvert search "lofi hip hop"The command:
- Runs a YouTube search using yt-dlp
- Shows a numbered list with title, channel, and duration
- Prompts you to select a result number
- Downloads the selected video through the existing download pipeline
Example interaction:
$ ytconvert search "lofi hip hop"
[1] Lofi Hip Hop Radio - Beats to Relax/Study To
Channel: Lofi Girl
Duration: 3:12:00
[2] Chill Lofi Mix
Channel: Chillhop Music
Duration: 1:45:10
Select video number: 2
Audio/video examples:
ytconvert search "chill beats" --audio
ytconvert search "chill beats" --video
ytconvert search "study music" --limit 5Download multiple YouTube URLs in one command by providing a text file with one URL per line.
https://www.youtube.com/watch?v=VIDEO_ID_1
https://www.youtube.com/watch?v=VIDEO_ID_2
https://youtu.be/VIDEO_ID_3
- One URL per line
- Empty lines and whitespace are ignored
- Invalid or non-YouTube lines are skipped with a warning
# Download all URLs as MP3 (default)
ytconvert batch urls.txt
# Download all URLs as MP3 explicitly
ytconvert batch urls.txt --audio
# Download all URLs as MP4
ytconvert batch urls.txt --video
# Download 5 at a time in parallel
ytconvert batch urls.txt --parallel 5
# Parallel audio downloads to a custom directory
ytconvert batch urls.txt --audio --parallel 3 --output ./downloads[1/3] Downloading: https://www.youtube.com/watch?v=VIDEO_ID_1
[2/3] Downloading: https://www.youtube.com/watch?v=VIDEO_ID_2
[3/3] Downloading: https://www.youtube.com/watch?v=VIDEO_ID_3
β All downloads completed. Completed: 3 succeeded, 0 failed
If any download fails, the rest continue and a summary is shown:
β Completed: 2 succeeded, 1 failed
- Archiving videos: Save a curated list of videos before they disappear
- Bulk audio downloads: Extract MP3s from a playlist you've exported manually
- Downloading playlists manually: Paste playlist URLs one per line and batch download
| Option | Description |
|---|---|
--audio |
Download all URLs as MP3 |
--video |
Download all URLs as MP4 |
--parallel N |
Download N URLs concurrently (default 1) |
--output |
Output directory for all downloads |
--verbose |
Show verbose yt-dlp output |
# Convert URL to MP3
ytconvert https://www.youtube.com/watch?v=VIDEO_ID
# Convert URL to MP4 at 720p
ytconvert https://www.youtube.com/watch?v=VIDEO_ID --format mp4 --quality 720p
# Search and download interactively
ytconvert search "lofi hip hop"
# Search and download selected result as MP3
ytconvert search "chill beats" --audio
# Search and download selected result as MP4
ytconvert search "chill beats" --videofrom ytconvert import YouTubeConverter
# Convert to MP3
converter = YouTubeConverter(output_dir="./downloads")
mp3_path = converter.convert_to_mp3("https://youtube.com/watch?v=VIDEO_ID")
print(f"Saved: {mp3_path}")
# Convert to MP4 with quality
mp4_path = converter.convert_to_mp4("https://youtube.com/watch?v=VIDEO_ID", quality="720p")
# Get video info only
info = converter.get_video_info("https://youtube.com/watch?v=VIDEO_ID")
print(f"Title: {info['title']}")
print(f"Duration: {info['duration']} seconds")import subprocess
import sys
def convert_youtube_video(url: str, format: str = "mp3", quality: str = "best"):
cmd = [
sys.executable, "-m", "ytconvert.cli",
url,
"--format", format,
"--output", "/path/to/downloads",
]
if format == "mp4" and quality != "best":
cmd.extend(["--quality", quality])
result = subprocess.run(cmd, capture_output=True, text=True)
if result.returncode == 0:
return {"success": True, "output": result.stdout}
else:
return {"success": False, "exit_code": result.returncode, "error": result.stderr}| Code | Meaning |
|---|---|
| 0 | Success |
| 1 | Invalid YouTube URL |
| 2 | Download failure |
| 3 | Format or quality unavailable |
| 4 | Unexpected error |
ytconvert-cli/
βββ ytconvert/
β βββ __init__.py # Package exports
β βββ cli.py # CLI entry point
β βββ converter.py # yt-dlp logic
β βββ validators.py # URL/format validation
**PyPI:** [ytconvert-cli 1.0.2](https://pypi.org/project/ytconvert-cli/1.0.2/)
β βββ utils.py # Utilities
βββ pyproject.toml # Packaging config
βββ README.md # This file
βββ LICENSE # MIT License
# Run tests
pytest
# Format code
black ytconvert/
ruff check ytconvert/ --fix
# Type check
mypy ytconvert/MIT License - see LICENSE
This tool is intended for downloading videos you have the right to download. Please respect copyright laws and YouTube's Terms of Service. The authors are not responsible for misuse.