Get Spotify tracks in true FLAC from Tidal, Qobuz & Amazon Music — no account required.
Project description
SpotiFLAC Python Module
Integrate SpotiFLAC directly into your Python projects. Perfect for building custom Telegram bots, automation tools, bulk downloaders, downloading music for Jellyfin or web interfaces.
Looking for a standalone app?
SpotiFLAC (Desktop)
Download music in true lossless FLAC from Tidal, Qobuz & Amazon Music for Windows, macOS & Linux
SpotiFLAC (Mobile)
SpotiFLAC for Android & iOS — maintained by @zarzet
Installation
pip install SpotiFLAC
Quick Start
The easiest way to use SpotiFLAC is through the built-in Interactive Wizard. Just run the command without any arguments:
SpotiFLAC
(Or python launcher.py if running from source)
Interactive Mode
SpotiFLAC features a smart Interactive Wizard that guides you step-by-step. On launch it automatically runs a service health check before asking any questions, so you always know which providers are reachable.
What the wizard does at startup:
- Service Health Check — probes all provider endpoints and shows availability inline (✅ / ❌) before asking anything
- URL History — shows your last 8 downloads so you can re-run one with a single keypress
- Folder Memory — remembers your last output directory and offers it as the default
- Profile Load — optionally restores a full saved configuration
Smart URL Detection: If you input an Artist URL, it will ask if you want to download "Featuring" tracks. It skips this question for albums or playlists.
Smart File Paths: If you input a Single Track URL, it will ask if you want to set a specific .flac output path. If you do, it intelligently skips all questions about filename formatting and subfolder organization.
Unified Quality Profiles: Automatically translates your desired quality tier across different services (like Tidal and Qobuz).
CLI Generator: At the end of the configuration, it generates and prints the exact CLI command for your specific setup, so you can copy and reuse it in your automated scripts.
Profile Save: After confirming the download, you can save the entire configuration as a named profile to reuse later.
from SpotiFLAC import SpotiFLAC
# Simple Download
SpotiFLAC(
url="https://open.spotify.com/track/4cOdK2wGLETKBW3PvgPWqT",
output_dir="./downloads"
)
CLI usage:
spotiflac url ./out --service tidal
Supported URL Types
SpotiFLAC supports the following URL formats for Spotify, Tidal, Apple Music, SoundCloud, YouTube and Pandora:
| Type | Spotify | Tidal | Apple Music | SoundCloud | YouTube / YT Music | Pandora |
|---|---|---|---|---|---|---|
| Track | open.spotify.com/track/... |
listen.tidal.com/track/... |
music.apple.com/.../song/... |
soundcloud.com/artist/track-slug |
youtube.com/watch?v=... · youtu.be/... |
pandora.com/artist/.../song/TR:... · pandora.app.link/... |
| Album / Set | open.spotify.com/album/... |
listen.tidal.com/album/... |
music.apple.com/.../album/... |
soundcloud.com/artist/sets/set-slug |
music.youtube.com/playlist?list=OLAK5uy_... |
— |
| Playlist | open.spotify.com/playlist/... |
listen.tidal.com/playlist/... |
music.apple.com/.../playlist/... |
— | youtube.com/playlist?list=PL... |
— |
| Discography (via artist URL) | open.spotify.com/artist/... |
listen.tidal.com/artist/.../discography/albums |
music.apple.com/.../artist/... |
— | — | — |
Note: SoundCloud and YouTube tracks are downloaded as MP3 (neither platform distributes lossless audio). Apple Music downloads as M4A/ALAC (lossless) or AAC depending on the selected quality. Pandora downloads as MP3 (mp3_192 by default) or M4A (aac_64 / aac_32). All other services deliver FLAC.
SoundCloud short links (
on.soundcloud.com/...) and mobile links (m.soundcloud.com/...) are automatically resolved. Tracking parameters (e.g.?utm_source=...) are stripped before processing.Apple Music track links with an
?i=song parameter (e.g.music.apple.com/us/album/album-name/id?i=trackid) are also supported.Pandora app links (
pandora.app.link/...) are automatically resolved to their canonical web URL. Pandora pretty URLs (e.g.pandora.com/artist/artist-name/album-name/song-name/TR:...) are fully supported.
Advanced Configuration
You can customize the download behavior, prioritize specific streaming services, and organize your files automatically into folders.
from SpotiFLAC import SpotiFLAC
SpotiFLAC(
url="https://open.spotify.com/album/41MnTivkwTO3UUJ8DrqEJJ",
output_dir="./MusicLibrary",
services=["qobuz", "amazon", "tidal", "spoti"],
filename_format="{year} - {album}/{track}. {title}",
use_artist_subfolders=True,
use_album_subfolders=True,
loop=60, # retry duration in minutes
track_max_retries=2, # extra per-track retries on failure
post_download_action="notify"
)
Service Health Check
SpotiFLAC can probe all provider endpoints before downloading to verify which ones are currently reachable.
In Interactive Mode this runs automatically at startup. In code or scripts you can call it directly:
from SpotiFLAC.core.health_check import (
run_health_check,
print_health_report,
get_working_providers,
)
results = run_health_check(["tidal", "qobuz", "deezer", "soundcloud", "pandora"])
print_health_report(results)
working = get_working_providers(results)
print("Available providers:", working)
# CLI: check all services then download
spotiflac https://open.spotify.com/track/... ./out --service tidal qobuz
The health check runs in parallel with a configurable timeout (default: 5 s per endpoint) and never blocks your download if a check fails.
Configuration Profiles
Save and reuse complete download configurations without re-typing them every time.
Save a profile
# Save current flags as "hires-tidal"
spotiflac https://... ./out \
--service tidal \
--quality HI_RES_LOSSLESS \
--use-album-subfolders \
--filename-format "{year} - {album}/{track}. {title}" \
--save-profile hires-tidal
Load a profile
# Load "hires-tidal" — flags override profile values when both are present
spotiflac https://... ./out --profile hires-tidal
In Python
from SpotiFLAC.core.profiles import save_profile, get_profile, list_profiles
# Save
save_profile("hires-tidal", {
"services": ["tidal"],
"quality": "HI_RES_LOSSLESS",
"use_album_subfolders": True,
"filename_format": "{year} - {album}/{track}. {title}",
})
# Load and use
cfg = get_profile("hires-tidal")
print(list_profiles()) # ['hires-tidal']
Profiles are stored at ~/.cache/spotiflac/profiles.json. In the Interactive Wizard, you are prompted to load a profile at startup and optionally save one at the end.
Batch Downloads
Pass a list of URLs to download them all in sequence. Failed tracks per URL are collected and can be retried with loop.
from SpotiFLAC import SpotiFLAC
SpotiFLAC(
url=[
"https://open.spotify.com/album/41MnTivkwTO3UUJ8DrqEJJ",
"https://open.spotify.com/playlist/37i9dQZF1DXcBWIGoYBM5M",
"https://listen.tidal.com/album/364272512",
],
output_dir="./MusicLibrary",
services=["tidal", "qobuz"],
use_album_subfolders=True,
)
Auto-Retry on Failure
Set track_max_retries (Python) or --retries (CLI) to automatically retry failed tracks.
Each retry cycles through all configured providers from the beginning, waiting exponentially longer between attempts (2 s → 4 s → 8 s …, capped at 30 s).
from SpotiFLAC import SpotiFLAC
SpotiFLAC(
url="https://open.spotify.com/album/...",
output_dir="./downloads",
services=["tidal", "qobuz", "deezer"],
track_max_retries=3, # up to 3 extra attempts per track
)
spotiflac https://open.spotify.com/album/... ./out \
--service tidal qobuz deezer \
--retries 3
Tip: Combine
--retrieswith--loopfor maximum resilience —--retrieshandles transient errors on individual tracks, while--loopre-queues permanently failed tracks after N minutes.
Post-Download Actions
Trigger an automatic action when all downloads in a session finish.
| Action | Description |
|---|---|
none |
Do nothing (default) |
open_folder |
Open the output folder in the system file manager |
notify |
Send an OS desktop notification with a summary |
command |
Run a custom shell command with {folder}, {succeeded}, {failed} placeholders |
Python
from SpotiFLAC import SpotiFLAC
# Open folder when done
SpotiFLAC(
url="https://open.spotify.com/album/...",
output_dir="./downloads",
post_download_action="open_folder",
)
# Custom command — sync to NAS when done
SpotiFLAC(
url="https://open.spotify.com/playlist/...",
output_dir="./downloads",
post_download_action="command",
post_download_command="rsync -av {folder}/ user@nas:/music/ && echo '{succeeded} tracks synced'",
)
CLI
# Desktop notification
spotiflac https://... ./out --post-action notify
# Open folder
spotiflac https://... ./out --post-action open_folder
# Custom command
spotiflac https://... ./out \
--post-action command \
--post-command "rsync -av {folder}/ user@nas:/music/"
Discography Download
Download the complete discography of an artist — both from Spotify and Tidal. Duplicate tracks (same ISRC across different releases) are automatically skipped.
Spotify
from SpotiFLAC import SpotiFLAC
# Full discography (albums + singles)
SpotiFLAC(
url="https://open.spotify.com/artist/1Xyo4u8uXC1ZmMpatF05PJ",
output_dir="./MusicLibrary",
services=["qobuz", "tidal"],
use_album_subfolders=True,
filename_format="{year} - {album}/{track}. {title}",
)
Tidal
from SpotiFLAC import SpotiFLAC
# Full discography
SpotiFLAC(
url="https://listen.tidal.com/artist/7804",
output_dir="./MusicLibrary",
services=["tidal"],
use_album_subfolders=True,
filename_format="{year} - {album}/{track}. {title}",
)
# Albums only
SpotiFLAC(
url="https://listen.tidal.com/artist/7804/discography/albums",
output_dir="./MusicLibrary",
services=["tidal"],
)
# Singles only
SpotiFLAC(
url="https://listen.tidal.com/artist/7804/discography/singles",
output_dir="./MusicLibrary",
services=["tidal"],
)
CLI
# Spotify artist — albums, singles + featuring tracks
spotiflac https://open.spotify.com/artist/... ./MusicLibrary \
--service tidal \
--include-featuring \
--use-album-subfolders \
--filename-format "{year} - {album}/{track}. {title}"
# Tidal artist (albums + singles)
spotiflac https://listen.tidal.com/artist/7804 ./MusicLibrary \
--service tidal \
--use-album-subfolders \
--filename-format "{year} - {album}/{track}. {title}"
Recommended folder structure for discographies
MusicLibrary/
Artist Name/
2019 - Album Title/
01. Song One.flac
02. Song Two.flac
2023 - Single Title/
01. Song Title.flac
Use --use-album-subfolders and --filename-format "{year} - {album}/{track}. {title}" to achieve this layout automatically.
SoundCloud Download
SpotiFLAC can download tracks, sets/albums, and full artist pages directly from SoundCloud. The output format is always MP3 128kbps (SoundCloud does not offer lossless streams). Metadata enrichment is supported; lyrics embedding is skipped as SoundCloud does not provide synchronized lyrics data.
Single Track
from SpotiFLAC import SpotiFLAC
SpotiFLAC(
url="https://soundcloud.com/artist/track-slug",
output_dir="./downloads",
services=["soundcloud"],
)
Playlist / Set
from SpotiFLAC import SpotiFLAC
SpotiFLAC(
url="https://soundcloud.com/artist/sets/set-slug",
output_dir="./downloads",
services=["soundcloud"],
use_album_subfolders=True,
)
Artist Page (all public tracks)
from SpotiFLAC import SpotiFLAC
SpotiFLAC(
url="https://soundcloud.com/artist",
output_dir="./downloads",
services=["soundcloud"],
use_artist_subfolders=True,
)
Deezer Download
SpotiFLAC can use Deezer as a download service when sourcing tracks identified by other input platforms (Spotify, Tidal, etc.). Deezer is resolved by ISRC, with an automatic text-search fallback. The output format is FLAC.
Note: Deezer URLs cannot be used as input — use a Spotify or Tidal link and set
deezeras the service.
from SpotiFLAC import SpotiFLAC
SpotiFLAC(
url="https://open.spotify.com/track/4cOdK2wGLETKBW3PvgPWqT",
output_dir="./downloads",
services=["deezer", "tidal"], # Deezer first, Tidal as fallback
)
Apple Music Download
SpotiFLAC supports Apple Music as both an input URL source and a download service. The output format is M4A (ALAC lossless or AAC depending on quality).
from SpotiFLAC import SpotiFLAC
SpotiFLAC(
url="https://music.apple.com/us/album/album-name/123456789?i=987654321",
output_dir="./downloads",
services=["apple"],
quality="alac",
)
Apple Music quality options:
alac(lossless, default),atmos(Dolby Atmos Spatial Audio),ac3(Dolby Digital),aac,aac-legacy.
YouTube Download
SpotiFLAC can download tracks, playlists and albums from YouTube Music (and standard YouTube). The output format is always MP3.
from SpotiFLAC import SpotiFLAC
SpotiFLAC(
url="https://music.youtube.com/watch?v=dQw4w9WgXcQ",
output_dir="./downloads",
services=["youtube"],
)
Pandora Download
SpotiFLAC can download individual tracks from Pandora using both web URLs and app links. The output format is MP3 (mp3_192 by default) or M4A (aac_64 / aac_32). Metadata enrichment via Deezer and the full MusicBrainz + lyrics pipeline are supported.
Note: Pandora does not offer lossless streams. Album and playlist downloads are not supported — only individual tracks.
Single Track (web URL)
from SpotiFLAC import SpotiFLAC
SpotiFLAC(
url="https://www.pandora.com/artist/artist-name/album-name/song-name/TR:12345678",
output_dir="./downloads",
services=["pandora"],
)
Single Track (app link)
from SpotiFLAC import SpotiFLAC
SpotiFLAC(
url="https://pandora.app.link/abcdef1234",
output_dir="./downloads",
services=["pandora"],
)
Quality selection
from SpotiFLAC import SpotiFLAC
# High quality MP3 (default)
SpotiFLAC(
url="https://www.pandora.com/artist/.../TR:12345678",
output_dir="./downloads",
services=["pandora"],
quality="mp3_192",
)
# Medium quality AAC
SpotiFLAC(
url="https://www.pandora.com/artist/.../TR:12345678",
output_dir="./downloads",
services=["pandora"],
quality="aac_64",
)
With fallback to another provider
from SpotiFLAC import SpotiFLAC
SpotiFLAC(
url="https://www.pandora.com/artist/.../TR:12345678",
output_dir="./downloads",
services=["pandora", "tidal"], # Pandora first, Tidal as fallback
)
CLI
# High quality MP3 (default)
spotiflac https://www.pandora.com/artist/.../TR:12345678 ./downloads \
--service pandora
# Medium quality AAC
spotiflac https://www.pandora.com/artist/.../TR:12345678 ./downloads \
--service pandora \
--quality aac_64
# App link
spotiflac https://pandora.app.link/abcdef1234 ./downloads \
--service pandora
Pandora quality options:
mp3_192(High, default),aac_64(Medium),aac_32(Low).
Custom Output Path (single tracks)
For single track downloads you can specify the exact file path instead of relying on output_dir + filename_format.
from SpotiFLAC import SpotiFLAC
SpotiFLAC(
url="https://open.spotify.com/track/4cOdK2wGLETKBW3PvgPWqT",
output_dir="./downloads",
output_path="files/song.flac"
)
Note:
output_pathis automatically ignored when the URL points to an album, playlist, or artist/discography.
Qobuz Token (Optional)
Setting a personal Qobuz token improves metadata resolution reliability. The token is used as a last resort fallback — requests are first attempted anonymously, and only if they fail (HTTP 400/401) the token is injected. A free Qobuz account is sufficient.
How to Extract Your Token
- Log in to play.qobuz.com
- Open DevTools with F12 → go to the Network tab
- Play any track or perform any search to trigger API calls
- Filter requests by typing
api.jsonin the search bar - Click on any request to
www.qobuz.com/api.json/... - In the Request Headers panel, look for: x-user-auth-token: your_token_here
- Copy the value — that is your token
How to Apply Tokens in SpotiFLAC
Interactive Wizard: The wizard prompts you to paste your Qobuz token during configuration.
Environment Variable:
export QOBUZ_AUTH_TOKEN="YOUR_TOKEN_HERE"
Python:
from SpotiFLAC import SpotiFLAC
SpotiFLAC(
url="URL",
output_dir="./downloads",
qobuz_token="YOUR_QOBUZ_TOKEN",
)
config.json:
{
"qobuz_token": "YOUR_QOBUZ_TOKEN"
}
CLI program usage
Program can be downloaded for Windows, Linux (x86 and ARM) and MacOS. The downloads are available under the releases.
Program can also be ran by downloading the python files and calling python launcher.py with the arguments.
Windows example usage:
./SpotiFLAC-Windows.exe url
output_dir
[--service tidal qobuz deezer amazon spoti soundcloud youtube apple pandora]
[--filename-format "{title} - {artist}"]
[--output-path "files/song.flac"]
[--quality LOSSLESS]
[--use-track-numbers]
[--use-album-track-numbers]
[--use-artist-subfolders]
[--use-album-subfolders]
[--first-artist-only]
[--qobuz-token TOKEN]
[--loop minutes]
[--verbose]
[--no-lyrics]
[--lyrics-providers spotify apple musixmatch amazon lrclib]
[--no-enrich]
[--enrich-providers deezer apple qobuz tidal soundcloud]
[--retries N]
[--post-action none|open_folder|notify|command]
[--post-command "CMD with {folder} {succeeded} {failed}"]
[--profile NAME]
[--save-profile NAME]
Linux / Mac example usage:
chmod +x SpotiFLAC-Linux-arm64
./SpotiFLAC-Linux-arm64 url
output_dir
[--service tidal qobuz deezer amazon spoti soundcloud youtube apple pandora]
[--filename-format "{title} - {artist}"]
[--output-path "files/song.flac"]
[--quality LOSSLESS]
[--use-track-numbers]
[--use-album-track-numbers]
[--use-artist-subfolders]
[--use-album-subfolders]
[--first-artist-only]
[--qobuz-token TOKEN]
[--loop minutes]
[--verbose]
[--no-lyrics]
[--lyrics-providers spotify apple musixmatch amazon lrclib]
[--no-enrich]
[--enrich-providers deezer apple qobuz tidal soundcloud]
[--retries N]
[--post-action none|open_folder|notify|command]
[--post-command "CMD with {folder} {succeeded} {failed}"]
[--profile NAME]
[--save-profile NAME]
(For ARM devices like Raspberry Pi, replace x86_64 with arm64)
API Reference
SpotiFLAC() Parameters
| Parameter | Type | Default | Description |
|---|---|---|---|
url |
str / list[str] |
Required | A single URL or a list of URLs (batch mode) for Spotify, Tidal, Apple Music, SoundCloud, YouTube or Pandora. |
output_dir |
str |
Required | The destination directory path where the audio files will be saved. |
output_path |
str |
None |
Exact destination file path for single track downloads. Overrides output_dir + filename_format. Automatically ignored for albums, playlists and artist discographies. |
services |
list |
["tidal"] |
Specifies which services to use and their priority order. Choices: tidal, qobuz, deezer, amazon, spoti, soundcloud, youtube, apple, pandora. |
filename_format |
str |
"{title} - {artist}" |
Format for naming downloaded files. See placeholders below. |
use_track_numbers |
bool |
False |
Prefixes the filename with the track number. |
use_album_track_numbers |
bool |
False |
Uses the track's original album number instead of the download queue position. |
use_artist_subfolders |
bool |
False |
Automatically organizes downloaded files into subfolders by artist. |
use_album_subfolders |
bool |
False |
Automatically organizes downloaded files into subfolders by album. |
first_artist_only |
bool |
False |
Uses only the first artist in tags and filename. |
include_featuring |
bool |
False |
When downloading an artist discography, also includes tracks where the artist appears as a featured artist. |
loop |
int |
None |
Duration in minutes to keep retrying permanently failed tracks after a full session completes. |
track_max_retries |
int |
0 |
Extra download attempts per track when all providers fail on the first try. Each retry cycles through all providers again with exponential backoff (2 s → 4 s → 8 s …, capped at 30 s). |
quality |
str |
"LOSSLESS" |
Download quality. Tidal: "DOLBY_ATMOS", "HI_RES_LOSSLESS", "LOSSLESS", "HIGH", "LOW". Qobuz: "6" (CD), "7" (Hi-Res), "27" (Hi-Res Max). Apple Music: "alac", "atmos", "ac3", "aac", "aac-legacy". Pandora: "mp3_192", "aac_64", "aac_32". |
allow_fallback |
bool |
True |
Automatically falls back to the next available quality tier if the requested quality is unavailable. |
log_level |
int |
logging.WARNING |
Python logging level. |
embed_lyrics |
bool |
True |
Whether to fetch and embed synchronized lyrics (LRC) into the audio file. |
lyrics_providers |
list |
["spotify", "apple", "musixmatch", "lrclib", "amazon"] |
Priority order of lyrics providers to attempt. |
enrich_metadata |
bool |
True |
Enables multi-provider metadata enrichment (HD covers, BPM, Labels, etc.). |
enrich_providers |
list |
["deezer", "apple", "qobuz", "tidal", "soundcloud"] |
Priority order of metadata providers to attempt. |
qobuz_token |
str |
None |
Optional Qobuz user auth token used as fallback for metadata resolution. Fallback: env QOBUZ_AUTH_TOKEN. |
post_download_action |
str |
"none" |
Action after all downloads finish: "none", "open_folder", "notify", "command". |
post_download_command |
str |
"" |
Shell command to run when post_download_action="command". Supports {folder}, {succeeded}, {failed} placeholders. |
Filename Format Placeholders
When customizing the filename_format string, you can use the following dynamic tags:
{title}— Track title{artist}— Track artist(s){album}— Album name{album_artist}— The artist(s) of the entire album{disc}— The disc number{track}— The track's original number in the album{position}— Download queue / Playlist position (zero-padded, e.g.01){date}— Full release date (e.g., YYYY-MM-DD){year}— Release year (e.g., YYYY){isrc}— Track ISRC code
CLI Flag Reference
| Flag | Short | Default | Description |
|---|---|---|---|
--service |
-s |
tidal |
One or more providers in priority order. Choices: tidal, qobuz, deezer, amazon, spoti, soundcloud, youtube, apple, pandora. |
--filename-format |
-f |
{title} - {artist} |
Filename template with placeholders. |
--output-path |
-o |
None |
Exact output file path for single track downloads. Ignored for albums, playlists and discographies. |
--quality |
-q |
LOSSLESS |
Audio quality. Tidal: DOLBY_ATMOS, HI_RES_LOSSLESS, LOSSLESS, HIGH, LOW. Qobuz: 6, 7, 27. Apple Music: alac, atmos, ac3, aac, aac-legacy. Pandora: mp3_192, aac_64, aac_32. |
--use-track-numbers |
False |
Prefix filenames with track numbers. | |
--use-album-track-numbers |
False |
Use the track's original album number instead of queue position. | |
--use-artist-subfolders |
False |
Organize files into per-artist subfolders. | |
--use-album-subfolders |
False |
Organize files into per-album subfolders. | |
--first-artist-only |
False |
Use only the first artist in tags and filename. | |
--include-featuring |
False |
Include tracks where the artist appears as a featured artist. Only applies to artist/discography URLs. | |
--qobuz-token |
None |
Qobuz user auth token (x-user-auth-token). |
|
--loop |
-l |
None |
Keep retrying permanently failed tracks every N minutes. |
--retries |
0 |
Extra per-track download attempts on failure. Cycles through all providers with exponential backoff. | |
--verbose |
-v |
False |
Enable debug logging. |
--no-lyrics |
False |
Disable lyrics embedding (lyrics are embedded by default). | |
--lyrics-providers |
spotify apple musixmatch lrclib amazon |
Lyrics provider priority order. | |
--no-enrich |
False |
Disable multi-provider metadata enrichment (enrichment is enabled by default). | |
--enrich-providers |
deezer apple qobuz tidal soundcloud |
Metadata enrichment provider priority order. | |
--post-action |
none |
Action after all downloads finish: none, open_folder, notify, command. |
|
--post-command |
"" |
Shell command for --post-action=command. Placeholders: {folder}, {succeeded}, {failed}. |
|
--profile |
None |
Load a saved profile. CLI flags override profile values. | |
--save-profile |
None |
Save current CLI configuration as a named profile after the run. |
MusicBrainz Enrichment
SpotiFLAC automatically queries MusicBrainz in the background (when an ISRC is available) while the audio is being downloaded, adding professional-grade tags at no extra time cost. Fields written when found:
| Tag | Description |
|---|---|
GENRE |
Genre(s), sorted by popularity (up to 5) |
BPM |
Beats per minute |
LABEL / ORGANIZATION |
Record label name |
CATALOGNUMBER |
Catalog number |
BARCODE |
Release barcode / UPC |
ORIGINALDATE / ORIGINALYEAR |
First-ever release date |
RELEASECOUNTRY |
Country of release |
RELEASESTATUS |
Release status (e.g. Official) |
RELEASETYPE |
Release type (e.g. Album, Single) |
MEDIA |
Media format (e.g. CD, Digital Media) |
SCRIPT |
Script of the release text |
ARTISTSORT |
Artist sort name for file managers |
MUSICBRAINZ_TRACKID |
MusicBrainz recording ID |
MUSICBRAINZ_ALBUMID |
MusicBrainz release ID |
MUSICBRAINZ_ARTISTID |
MusicBrainz artist ID |
MUSICBRAINZ_RELEASEGROUPID |
MusicBrainz release group ID |
MUSICBRAINZ_ALBUMARTISTID |
MusicBrainz album artist ID |
ALBUMARTISTSORT |
Album artist sort name for file managers |
Download Validation
After each download, SpotiFLAC validates the file to detect common issues:
- Preview detection — if the expected duration is ≥ 60 s but the downloaded file is ≤ 35 s, the file is deleted and the download is retried with the next provider.
- Duration mismatch — for tracks longer than 90 s, a deviation greater than 25% (or 15 s minimum) from the expected duration is treated as a corrupt download and the file is removed.
Want to support the project?
If this software is useful and brings you value, consider supporting the project by buying me a coffee. Your support helps keep development going.
API Credits
Song.link · hifi-api · dabmusic.xyz · afkarxyz · MusicBrainz · SoundCloud · Apple Music · YouTube Music · Pandora
[!TIP]
Star Us, You will receive all release notifications from GitHub without any delay ~
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file spotiflac-0.5.4.tar.gz.
File metadata
- Download URL: spotiflac-0.5.4.tar.gz
- Upload date:
- Size: 156.9 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.11.15
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
6851c538e8ecf0e344e25528d11b9b459dc1fce1cedba72bfe3a062865095c00
|
|
| MD5 |
8373702d4491d6d77750d150df6e43a4
|
|
| BLAKE2b-256 |
0e92600adc5a7490d8cf96c70d4189090483d3698c24a03b8686e023ecf92ded
|
File details
Details for the file spotiflac-0.5.4-py3-none-any.whl.
File metadata
- Download URL: spotiflac-0.5.4-py3-none-any.whl
- Upload date:
- Size: 161.7 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.11.15
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
9a089a71df7aef486144f714f958ba315e52d818eb1238a3fe23e41b14e95631
|
|
| MD5 |
b5a861b66b1747e057322774add76af3
|
|
| BLAKE2b-256 |
92dc7ae8f50bac48e59c4440a41b982ab263e67739358083f5cccfeab83e92aa
|