Skip to main content

Create/update a Spotify playlist from a local m3u playlist

Project description

Convert local playlists to Spotify playlists

Build, Test, Lint PyPI version

Supports m3u and m3u8 files in the Extended format encoded as UTF-8.

Take a look below for more details and debugging tips.

Usage

usage: tospotify [-h] [--verbose] [--public] [--convert]
                 [--playlist-id PLAYLIST_ID]
                 spotify_username playlist_path

Create/update a Spotify playlist from a local m3u playlist

positional arguments:
  spotify_username      Spotify username where playlist should be updated.
                        Your email address should work just fine, or could
                        find your user id through e.g. the developer console
  playlist_path         full path to the playlist

optional arguments:
  -h, --help            show this help message and exit
  --verbose             print all the steps when searching for songs
  --public              playlist is public, otherwise private
  --convert             convert from locale default to utf-8
  --playlist-id PLAYLIST_ID
                        do not create a new playlist, instead update the
                        existing playlist with this id

Example

  • Linux/MacOS

      tospotify --verbose "john.doe@gmail.com" "D:/playlist/name.m3u"
    
  • Windows*

      python -m tospotify "john.doe@gmail.com" "D:/playlist/name.m3u"
    

*entry_points does not seem to simply work on Windows

Requirements

  1. Python > 3.6

  2. Enable Developer Dashboard and your 'app'.

  3. Setup some environment variables:

Linux

export SPOTIPY_CLIENT_ID="<paste-from-dev-dashboard>"
export SPOTIPY_CLIENT_SECRET="<paste-from-dev-dashboard>"
export SPOTIPY_REDIRECT_URI="<your-chosen-uri>"

Windows

Same as linux but use set instead of export

Help

Encoding

Seeing unexpected characters in the log messages is a sign of faulty encoding.

This tool uses m3u8 library to parse the files, which relies on utf-8.

Encoding can be checked by opening the playlist in a text editor, such as Notepad++. If the playlist is in a different encoding, try using the --convert argument which will attempt to convert it to utf-8.

Alternatively, could try importing the playlist into your music player and using its export function to export as utf-8, if it exists. AIMP, for example, can do this.

Songs missing

This might happen when the file is not actually in the extended m3u format. This format looks like

#EXTM3U
#EXTINF:277,Faun - Sieben Raben
/Music/Selection/Faun - Sieben Raben.mp3

and is populated from file tags. For this example, the mp3 file contains the tags artist = Faun and title = Sieben Raben which then populate the #EXTINF line.

If your playlist only contain paths, try importing it in a (different) music player and exporting again. AIMP, for example, exports in the expected format.

What does tospotify actually do internally?

It tries various cleaning steps and search queries in an attempt to find the correct songs on Spotify.

The extended m3u format is important. As mentioned above, the ground truth is actually the artist and title tags stored in the songs themselves which are then reflected in the playlist. Looking at the example above, the format is essentially artist - title; this implicitly means that dashes - in the artist or title cannot be interpreted properly at the moment. Sorry, AC-DC :(

The tool then uses rules to compute various queries. Take for example the song Every Breath You Take by Sting and the Police. This can be stored in many ways. The artist could be Sting and the Police, Sting;The Police, Sting & the Police, The Police, etc. Then the title could be Every Breath You Take but also Every Breath You Take feat. Sting and other variations. Many of these are not found exactly as such on Spotify.

There can also be live versions, e.g. with title Every Breath You Take [live], covers by other artists, separate recordings of the song, and the list goes on. This song was actually recorded both by The Police with Sting and solo by Sting; both versions are available on Spotify!

Bit more complex than it initially seems :)

So this is what tospotify does; it will try to find the correct song through various rules derived from the data in the playlist.

Contributing

Take a look at the CONTRIBUTING file for more details. Pull requests are welcome!

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

tospotify-0.3.4.tar.gz (24.2 kB view details)

Uploaded Source

Built Distribution

tospotify-0.3.4-py3-none-any.whl (25.2 kB view details)

Uploaded Python 3

File details

Details for the file tospotify-0.3.4.tar.gz.

File metadata

  • Download URL: tospotify-0.3.4.tar.gz
  • Upload date:
  • Size: 24.2 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/5.0.0 CPython/3.12.2

File hashes

Hashes for tospotify-0.3.4.tar.gz
Algorithm Hash digest
SHA256 4152e89d8b7da6ee042317e0f4dfaea23e2ac0541aca0484e1a2f73e325436ee
MD5 bdce9cae7d5389f5f2556b369cd20a70
BLAKE2b-256 8439229b09c72e55d9c94532dd32a0d74d7e80d42b955cb63866aa8dae5fe726

See more details on using hashes here.

File details

Details for the file tospotify-0.3.4-py3-none-any.whl.

File metadata

  • Download URL: tospotify-0.3.4-py3-none-any.whl
  • Upload date:
  • Size: 25.2 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/5.0.0 CPython/3.12.2

File hashes

Hashes for tospotify-0.3.4-py3-none-any.whl
Algorithm Hash digest
SHA256 4a4ec93ef9f4e9c8eab90e56483dd0c3e499cec1a0fc1304fd0e0c5069c8eb36
MD5 68fcc04fa4432fc34ed488c5e1fe5a8b
BLAKE2b-256 34627172cdd488c5e2996d2bd7f8e8f363c213506606efe959a891f20050ba56

See more details on using hashes here.

Supported by

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