qobuz-dl/README.md

178 lines
5.3 KiB
Markdown
Raw Permalink Normal View History

# qobuz-dl
Search, explore and download Lossless and Hi-Res music from [Qobuz](https://www.qobuz.com/).
2021-02-03 22:19:08 +01:00
[![Donate](https://img.shields.io/badge/Donate-PayPal-green.svg)](https://www.paypal.com/cgi-bin/webscr?cmd=_s-xclick&hosted_button_id=VZWSWVGZGJRMU&source=url)
2020-12-08 05:28:21 +01:00
2020-08-10 04:47:51 +02:00
## Features
2020-08-13 06:52:16 +02:00
* Download FLAC and MP3 files from Qobuz
* Explore and download music directly from your terminal with **interactive** or **lucky** mode
* Download albums, tracks, artists, playlists and labels with **download** mode
* Download music from last.fm playlists (Spotify, Apple Music and Youtube playlists are also supported through this method)
* Queue support on **interactive** mode
2020-12-20 21:49:15 +01:00
* Effective duplicate handling with own portable database
* Support for albums with multiple discs
* Support for M3U playlists
* Downloads URLs from text file
* Extended tags
* And more
2020-08-10 04:47:51 +02:00
## Getting started
2020-12-08 05:28:21 +01:00
> You'll need an **active subscription**
2020-08-10 04:47:51 +02:00
#### Install qobuz-dl with pip
2020-12-10 05:24:10 +01:00
##### Linux / MAC OS
```
pip3 install --upgrade qobuz-dl
```
##### Windows
2020-08-10 04:47:51 +02:00
```
2020-12-10 05:24:10 +01:00
pip3 install windows-curses
2020-12-07 21:37:51 +01:00
pip3 install --upgrade qobuz-dl
2020-08-10 04:47:51 +02:00
```
#### Run qobuz-dl and enter your credentials
2020-12-07 21:37:51 +01:00
##### Linux / MAC OS
2020-08-10 04:47:51 +02:00
```
qobuz-dl
2020-08-10 04:47:51 +02:00
```
2020-12-07 21:37:51 +01:00
##### Windows
2020-08-10 04:47:51 +02:00
```
2020-12-07 21:37:51 +01:00
qobuz-dl.exe
2020-08-10 04:47:51 +02:00
```
> If something fails, run `qobuz-dl -r` to reset your config file.
## Examples
### Download mode
Download URL in 24B<96khz quality
```
qobuz-dl dl https://play.qobuz.com/album/qxjbxh1dc3xyb -q 7
```
Download multiple URLs to custom directory
```
qobuz-dl dl https://play.qobuz.com/artist/2038380 https://play.qobuz.com/album/ip8qjy1m6dakc -d "Some pop from 2020"
```
Download multiple URLs from text file
```
qobuz-dl dl this_txt_file_has_urls.txt
```
Download albums from a label and also embed cover art images into the downloaded files
```
qobuz-dl dl https://play.qobuz.com/label/7526 --embed-art
```
Download a Qobuz playlist in maximum quality
```
qobuz-dl dl https://play.qobuz.com/playlist/5388296 -q 27
```
Download all the music from an artist except singles, EPs and VA releases
```
qobuz-dl dl https://play.qobuz.com/artist/2528676 --albums-only
```
#### Last.fm playlists
> Last.fm has a new feature for creating playlists: you can create your own based on the music you listen to or you can import one from popular streaming services like Spotify, Apple Music and Youtube. Visit: `https://www.last.fm/user/<your profile>/playlists` (e.g. https://www.last.fm/user/vitiko98/playlists) to get started.
Download a last.fm playlist in the maximum quality
```
qobuz-dl dl https://www.last.fm/user/vitiko98/playlists/11887574 -q 27
```
Run `qobuz-dl dl --help` for more info.
2020-12-10 04:39:16 +01:00
### Interactive mode
Run interactive mode with a limit of 10 results
```
qobuz-dl fun -l 10
```
Type your search query
```
Logging...
Logged: OK
Membership: Studio
Enter your search: [Ctrl + c to quit]
- fka twigs magdalene
```
2020-12-11 19:37:57 +01:00
`qobuz-dl` will bring up a nice list of releases. Now choose whatever releases you want to download (everything else is interactive).
2020-12-10 04:39:16 +01:00
Run `qobuz-dl fun --help` for more info.
### Lucky mode
Download the first album result
```
qobuz-dl lucky playboi carti die lit
```
Download the first 5 artist results
```
qobuz-dl lucky joy division -n 5 --type artist
```
Download the first 3 track results in 320 quality
```
qobuz-dl lucky eric dolphy remastered --type track -n 3 -q 5
```
2020-12-19 18:16:45 +01:00
Download the first track result without cover art
```
qobuz-dl lucky jay z story of oj --type track --no-cover
```
Run `qobuz-dl lucky --help` for more info.
### Other
Reset your config file
```
qobuz-dl -r
```
By default, `qobuz-dl` will skip already downloaded items by ID with the message `This release ID ({item_id}) was already downloaded`. To avoid this check, add the flag `--no-db` at the end of a command. In extreme cases (e.g. lost collection), you can run `qobuz-dl -p` to completely reset the database.
2020-08-10 04:47:51 +02:00
## Usage
```
usage: qobuz-dl [-h] [-r] {fun,dl,lucky} ...
The ultimate Qobuz music downloader.
See usage examples on https://github.com/vitiko98/qobuz-dl
2020-08-10 04:47:51 +02:00
optional arguments:
-h, --help show this help message and exit
-r, --reset create/reset config file
-p, --purge purge/delete downloaded-IDs database
commands:
run qobuz-dl <command> --help for more info
(e.g. qobuz-dl fun --help)
{fun,dl,lucky}
fun interactive mode
dl input mode
lucky lucky mode
2020-08-10 04:47:51 +02:00
```
## Module usage
2020-12-15 03:06:29 +01:00
Using `qobuz-dl` as a module is really easy. Basically, the only thing you need is `QobuzDL` from `core`.
```python
2020-12-19 18:16:45 +01:00
import logging
from qobuz_dl.core import QobuzDL
2020-12-19 18:16:45 +01:00
logging.basicConfig(level=logging.INFO)
email = "your@email.com"
password = "your_password"
qobuz = QobuzDL()
qobuz.get_tokens() # get 'app_id' and 'secrets' attrs
qobuz.initialize_client(email, password, qobuz.app_id, qobuz.secrets)
qobuz.handle_url("https://play.qobuz.com/album/va4j3hdlwaubc")
```
Attributes, methods and parameters have been named as self-explanatory as possible.
2020-08-10 04:47:51 +02:00
## A note about Qo-DL
`qobuz-dl` is inspired in the discontinued Qo-DL-Reborn. This tool uses two modules from Qo-DL: `qopy` and `spoofer`, both written by Sorrow446 and DashLt.
2020-08-10 04:47:51 +02:00
## Disclaimer
* This tool was written for educational purposes. I will not be responsible if you use this program in bad faith. By using it, you are accepting the [Qobuz API Terms of Use](https://static.qobuz.com/apps/api/QobuzAPI-TermsofUse.pdf).
* `qobuz-dl` is not affiliated with Qobuz