Skip to main content

CLI tool for searching YouTube/YTMusic and downloading audio/video from 1000+ platforms

Project description

fm-dlp — Download and tag music/video from YouTube, YTMusic, and 1000+ sites

Python PyPI License Platform Ruff

Download and tag high-quality music and video from YouTube, YouTube Music, and 1000+ sites — all from your terminal.

✨ Features

  • Multi-platform Search — YouTube, YouTube Music (tracks & albums)
  • 1000+ Supported Sites — Any site yt-dlp supports
  • Audio/Video Formats — MP3, FLAC, MP4, MKV, WebM, and more with configurable bitrate
  • Metadata Embedding — Title, artist, album tags + thumbnail (audio)
  • Proxy Support — HTTP, HTTPS, SOCKS4/SOCKS5/SOCKS5h
  • Cookie Support — Browser cookies for restricted content
  • Parallel Downloads — Async support for multiple URLs
  • Cross-platform Config — XDG, AppData, Application Support

🚀 Quick Start

Prerequisites

  • Python 3.10+ & FFmpeg

Installation

pip install fm-dlp        # pip
uv pip install fm-dlp     # uv
pipx install fm-dlp       # pipx

Usage

fm-dlp config ~/Music                          # Set download directory (first run)
fm-dlp search "artist" --platform yt-music     # Search tracks
fm-dlp search "album" --type album             # Search albums
fm-dlp download "URL" --codec mp3 --kbps 320   # Download audio
fm-dlp download "URL" --codec mp4              # Download video

📋 Commands

search — Find music

fm-dlp search <query> [--limit 10] [--platform yt-music|yt-video] [--type track|album] [--proxy URL]
Option Default Description
--platform yt-music Search platform: yt-music, yt-video
--type track Content type: track, album
--limit 10 Number of results
--proxy Proxy URL

download — Download audio/video

fm-dlp download <urls> [--codec CODEC] [--kbps 256] [--quiet] [--max-concurrent 5] [--cookies browser] [--proxy URL]
Option Default Description
--codec m4a/opus Audio: mp3, aac, flac, m4a, opus, vorbis, wav
Video: mp4, mkv, webm, mov, avi, flv
--kbps 256 Bitrate 64–320 (audio only)
--max-concurrent 5 Parallel downloads
--quiet Suppress output
--no-metadata Disable metadata embedding
--cookies Browser: chrome, firefox, edge, etc.
--proxy http://, socks5://, etc.

config — Set download path

fm-dlp config ~/Music    # Set directory
fm-dlp config             # View current path

Stored in: ~/.config/fm-dlp/ (Linux), ~/Library/Application Support/fm-dlp/ (macOS), %APPDATA%\fm-dlp\ (Windows).

📖 Examples

# Search
fm-dlp search "Sewerslvt" --limit 10 --platform yt-music
fm-dlp search "usedcvnt" --type album

# Audio
fm-dlp download "URL" --codec flac
fm-dlp download "URL1 URL2 URL3" --codec mp3 --kbps 320

# Video
fm-dlp download "URL" --codec mp4
fm-dlp download "URL" --codec mkv

# Advanced
fm-dlp download "URL" --cookies firefox
fm-dlp download "URL" --proxy socks5://127.0.0.1:9050
fm-dlp download "URL1 URL2 URL3 URL4 URL5" --quiet --max-concurrent 10

📁 Project Structure

fm-dlp/
├── modules/
│   ├── __init__.py          # Package initializer
│   ├── cli.py               # CLI entry point (cliss)
│   ├── commands/
│   │   ├── search.py        # YouTube & YTMusic search
│   │   └── download.py      # Async download engine (yt-dlp)
│   └── utils/
│       ├── configer.py      # JSON config manager
│       └── validator.py     # Input validation & dependency checks
├── pyproject.toml
├── README.md
└── LICENSE

🔧 Requirements

Dependency Purpose
yt-dlp YouTube extraction & download
ytmusicapi YouTube Music API
mutagen Audio metadata tagging
platformdirs Cross-platform config paths
color-kiss Terminal colors
cliss CLI framework
FFmpeg Audio/video conversion (system)

❓ FAQ

Why fm-dlp when yt-dlp exists?

fm-dlp wraps yt-dlp's complex flags into a clean workflow: search with readable output, download with a single --codec option, and automatic metadata tagging from structured music data — no memorising flag combinations.

macOS defaults to M4A, others to Opus — why?

macOS treats M4A/AAC as first-class (Finder, Music.app, QuickTime). Linux/Windows default to Opus for superior quality at equivalent bitrates. Override with --codec.

How does CLI parsing work?

Uses cliss — a zero-dependency wrapper over argparse with type-driven arguments and async support.

Proxy support?

Protocol Download Search (yt-video) Search (yt-music)
http://, https://
socks4://, socks5://, socks5h://

📄 License

MIT License — see LICENSE file.

🙏 Acknowledgments


Author: Fkernel653 Repository: github.com/Fkernel653/fm-dlp PyPI: pypi.org/project/fm-dlp

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

fm_dlp-3.4.3.tar.gz (13.1 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

fm_dlp-3.4.3-py3-none-any.whl (14.8 kB view details)

Uploaded Python 3

File details

Details for the file fm_dlp-3.4.3.tar.gz.

File metadata

  • Download URL: fm_dlp-3.4.3.tar.gz
  • Upload date:
  • Size: 13.1 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.15.0b1

File hashes

Hashes for fm_dlp-3.4.3.tar.gz
Algorithm Hash digest
SHA256 84fc71edbcd4f31155bc2e257fce0b167f68a472bd8111d3d64b456ead4affd8
MD5 dd1b03c7afe83d6086d5c6af5f2f4adb
BLAKE2b-256 ea8bcc1f634eb4c0d6894178d60f6c5d2d5936f38bd8d70efd761a7f8dd3f70f

See more details on using hashes here.

File details

Details for the file fm_dlp-3.4.3-py3-none-any.whl.

File metadata

  • Download URL: fm_dlp-3.4.3-py3-none-any.whl
  • Upload date:
  • Size: 14.8 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.15.0b1

File hashes

Hashes for fm_dlp-3.4.3-py3-none-any.whl
Algorithm Hash digest
SHA256 ed02f28697b7a510fd06068f9dab6b51dc38a73746dd9706d0f7f3b94bd385b0
MD5 09ca47d1ecdc003cddf3ed08e374d646
BLAKE2b-256 7b9ceb8fabb211d5987c0180d04b0611cde2b53acfb921d7d0cbb3b9b532cb26

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page