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/
├── fm_dlp/
│   ├── __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.5.3.tar.gz (15.3 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.5.3-py3-none-any.whl (14.7 kB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: fm_dlp-3.5.3.tar.gz
  • Upload date:
  • Size: 15.3 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.5.3.tar.gz
Algorithm Hash digest
SHA256 09f09879d60ebade3d61aff628dd8cd7da454123dba4e4c2a0a09371576d1dcf
MD5 264c6c143ae7d304a029a9b422b2be05
BLAKE2b-256 d1c1cb08fe5625ad8ff267d6c0997de6499ea2adc72af893823b76c1750ff320

See more details on using hashes here.

File details

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

File metadata

  • Download URL: fm_dlp-3.5.3-py3-none-any.whl
  • Upload date:
  • Size: 14.7 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.5.3-py3-none-any.whl
Algorithm Hash digest
SHA256 fe115ea67555432200523d77ea7bf4ec25246268458a9e6c1b03826360e88daa
MD5 7ae627d82bbbe0bce1d5363e4fa04a8a
BLAKE2b-256 01cb027447635b8778ba422541f21ce26b0ea610fd3a2f5c84e06bc7441f61dc

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