Skip to main content

A fast, zero-config CLI tool to download and sync playlists from Spotify, Apple Music, Tidal, YouTube, and SoundCloud.

Project description

SDM - SDM Downloads Music

sdm is a fast, lightweight, and zero-config CLI tool to download and sync Playlists, Albums, and Tracks from Spotify, Apple Music, Tidal, YouTube, and SoundCloud.

Why sdm?

Recently, Spotify restricted their Web API, requiring developers to have a Premium subscription, which broke popular open-source tools with 403 Forbidden errors.

sdm was built to completely bypass these restrictions. It uses native web scraping to extract flawless metadata directly from streaming services, pairs it with yt-dlp to fetch the highest-quality audio, and embeds the tags natively. No API keys required.

Features

  • Universal Support: Spotify, Apple Music, Tidal, YouTube, and SoundCloud.
  • Smart Syncing: Two-way mirroring. Run sdm sync to fetch new tracks and clean up removed ones.
  • Multi-Format: Download in M4A (default), MP3, FLAC, or OPUS with native tags.
  • Perfect Metadata: Embeds Track, Artist, Album, Cover Art, Track/Disc Numbers, Genre, and Release Year.
  • Advanced Processing: Synced lyrics via LRCLIB, custom 2-pass EBU R128 (-14 LUFS) audio normalization algorithm for perfectly balanced studio-grade levels without dynamic range compression artifacts, and SponsorBlock trimming.

Installation

You must have Python 3.8+ installed on your system. (Windows users: Make sure to check the "Add Python to PATH" box during installation!)

Install directly from PyPI:

pip install sdm-pycli

Usage

Open a terminal in the folder where you want your music saved, then run the commands below.

Playlist

To download a playlist, run

sdm download [playlistUrl]

Example:

sdm download https://open.spotify.com/playlist/37i9dQZF1E8NjgPSXnmGkI?si=O0kgUaFcQnatcvlZzS9yJw

Album

To download an album, run

sdm download [albumUrl]

Example:

sdm download https://open.spotify.com/album/6eUW0wxWtzkFdaEFsTJto6?si=nYD6g_tZQvuFsMzyKG2sRA

Track

To download a single track, run

sdm download [trackUrl]

Example:

sdm download https://open.spotify.com/track/4PTG3Z6ehGkBFwjybzWkR8?si=1d83934b63464e9e

Apple Music

Apple Music albums, playlists, and songs are also supported.

sdm download https://music.apple.com/us/album/starboy/1440871397

Sync

sdm remembers the source URL for each folder. To update a previously downloaded folder with any changes from the remote playlist, run

sdm sync [directory]

Example:

sdm sync "C:\Users\You\Music\My Playlist"

Inject

To import a local audio file into your playlist with official metadata and protect it from future sync deletions, run

sdm inject [filePath] [trackUrl]

Example:

sdm inject "C:\Users\You\Downloads\song.mp3" https://open.spotify.com/track/0VjIjW4GlUZAMYd2vXMi3b

Config

You can set persistent default options (like format, workers, or API keys) so you never have to type them again:

sdm config --format flac --workers 5 --lastfm-key "YOUR_API_KEY"

Tag

To recursively scan an existing local directory and enrich the audio files with extensive Last.fm metadata (Genres, Track Bios, and MusicBrainz IDs) without redownloading them, run:

sdm tag [directory]

Example:

sdm tag "C:\Users\You\Music\My Playlist"

Search

To search and download a single track directly from YouTube Music, run

sdm search [query]

Example:

sdm search "Never Gonna Give You Up - Rick Astley"

Stats

To show statistics for your local library (such as track count, total size, and format distribution), run

sdm stats [directory]

Example:

sdm stats "C:\Users\You\Music"

Migrate

To bulk convert a downloaded library to a different audio format, run

sdm migrate --dir [directory] [target_format]

Example:

sdm migrate --dir "C:\Users\You\Music\FLAC Library" opus

Options & Flags

Flag Description
-o, --output Save to a specific directory
-f, --format Audio format: m4a, mp3, flac, opus (default: m4a)
-w, --workers Number of concurrent downloads (default: 3)
--cleanup Run sync cleanup logic on a standard download to remove orphaned files
--index Manually override the track index number when injecting a file
--dir Target directory for the migrate and stats commands
--lyrics Fetch and embed synced lyrics from LRCLIB
--normalize Apply custom 2-pass EBU R128 (-14 LUFS) volume normalization
--sponsor-block Trim non-music sections from YouTube sources
--dry-run Simulate a sync/download without making changes
--no-delete Download new tracks but never delete local files
--refresh-metadata Re-tag existing files with the latest metadata (alias: --refresh)
--cookies Pass browser cookies for age-restricted content
--lastfm-key Enable extensive track-level genres and wiki summaries via Last.fm API

Example with flags:

sdm download https://open.spotify.com/playlist/37i9dQZF1E8UXBoz02kGID -f flac --lyrics --normalize

Music Sourcing & Audio Quality

sdm fetches flawless metadata (tags, cover art, tracklists) directly from Spotify, Apple Music, and Tidal, but sources the actual audio streams from YouTube.

Unlike other tools that require your Premium credentials and risk permanent account bans by ripping directly from encrypted servers, sdm acts as a safe, unauthenticated metadata matcher. It reliably delivers DRM-free audio (up to 256kbps AAC or Opus) perfectly packaged to match the original release.

Legal Disclaimer

Users are responsible for their actions. We do not support unauthorized downloading of copyrighted material. sdm is open-source (MIT License) for educational and personal use only.


Important Notes:

  • Spotify Playlists must be set to Public. Private playlists and personalized mixes will not work.
  • Explicit Content: If YouTube blocks downloads, pass browser cookies with --cookies firefox. Firefox is recommended.

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

sdm_pycli-2.0.0.tar.gz (31.7 kB view details)

Uploaded Source

Built Distribution

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

sdm_pycli-2.0.0-py3-none-any.whl (30.5 kB view details)

Uploaded Python 3

File details

Details for the file sdm_pycli-2.0.0.tar.gz.

File metadata

  • Download URL: sdm_pycli-2.0.0.tar.gz
  • Upload date:
  • Size: 31.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.11.3

File hashes

Hashes for sdm_pycli-2.0.0.tar.gz
Algorithm Hash digest
SHA256 a9290580bcb76ecf6bdd9163808cc163f816ec07c0a1bf85bfbafb39b25075f0
MD5 ec43238976a9f11dd8165aa7cc021a40
BLAKE2b-256 a4848f0baa10509fad0e62e727468b2579fd08f99ea99ab5af1c72ca54a099cd

See more details on using hashes here.

File details

Details for the file sdm_pycli-2.0.0-py3-none-any.whl.

File metadata

  • Download URL: sdm_pycli-2.0.0-py3-none-any.whl
  • Upload date:
  • Size: 30.5 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.11.3

File hashes

Hashes for sdm_pycli-2.0.0-py3-none-any.whl
Algorithm Hash digest
SHA256 a4555c131b05b551d4e71666c8cf35a7c21e101124b531d18499d305de6e189b
MD5 1d846716449006a8758c0e6a4f12675f
BLAKE2b-256 75cf0002fcfe14ce9cc6968dec41993c13fece30eeb11b666f6ba75922cc02a5

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