Skip to main content

A playlist generator for creating local playlists using Spotify curated playlists

Project description

Spotipylist

A playlist generator for creating local playlists using Spotify's curated playlists

Table of Contents

General Info

This project is my final project for CS50x (Harvard University's Intro to Computer Science hosted on edX.org)

The main purpose is to make creating playlists from my personal music library faster, easier, and better by using the track lists of many of the fantastic playlists that are already hosted on Spotify.

Video Demo: https://youtu.be/hiCw-1UxLPs

Dependencies

Spotipylist uses the following:

  • Python 3.6 or later
  • spotipy 2.19.0 or later
  • rapidfuzz 1.7.1 or later

Setup

Spotipylist is installable using pip:

pip install spotipylist

OR

python3 -m pip install spotipylist

Currently, your music library must be arranged the in the following format:

  • Folder structure:

    <music_library>/<artist>/[<album>/]
    
  • Filenames

    <track_number> - <track_name>.mp3
    

    where track_number is 2 digits (e.g. 01 for track number 1)

This is mostly a personal choice as that's how my music library is structured. I have considered other options, such as adding support for ID3 tags, and probably will add one or more in future releases.

Usage

  1. Set the following environment variables:

    • SPOTIPY_CLIENT_ID
    • SPOTIPY_CLIENT_SECRET
    • SPOTIPYLIST_MUSIC_LIBRARY

    To set SPOTIPY_CLIENT_ID and SPOTIPY_CLIENT_SECRET, first create a new app on https://developers.spotify.com, then use the client_id and client_secret given there.

    Set SPOTIPYLIST_MUSIC_LIBRARY with the absolute path to your local music library.

  2. Because you installed from PyPi, you can run spotipylist in your terminal with

    spotipylist
    
  3. You will be prompted for the Spotify playlist ID you want to copy.

  4. When prompted, input the name you would like to give to your new playlist.

    • New playlist will be saved in your music library as <playlist_name>.m3u, overwriting any playlist of the same name.
  5. Finally, if your music library does not contain some of the songs in the Spotify playlist, the name and artist of each of those tracks will be saved to missing_tracks.txt in your music library. You'll be prompted with the following message:

    • Some songs from this playlist were not found in your library. See missing_tracks.txt for details.

License

Spotipylist is licensed under the MIT license.

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

spotipylist-0.2.1.tar.gz (6.2 kB view details)

Uploaded Source

Built Distribution

spotipylist-0.2.1-py3-none-any.whl (7.5 kB view details)

Uploaded Python 3

File details

Details for the file spotipylist-0.2.1.tar.gz.

File metadata

  • Download URL: spotipylist-0.2.1.tar.gz
  • Upload date:
  • Size: 6.2 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.1 CPython/3.10.7

File hashes

Hashes for spotipylist-0.2.1.tar.gz
Algorithm Hash digest
SHA256 8bd36146443a377ebf1c318771bcf6ea9b1256528995bed84aa2a20113fea00e
MD5 6ab9bc8fb9315b1123f36c86768c1418
BLAKE2b-256 7d6a49f4a3fe928d7262a81510ff36d3fa904e336693f44c4303c45e1ed6fbff

See more details on using hashes here.

Provenance

File details

Details for the file spotipylist-0.2.1-py3-none-any.whl.

File metadata

  • Download URL: spotipylist-0.2.1-py3-none-any.whl
  • Upload date:
  • Size: 7.5 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.1 CPython/3.10.7

File hashes

Hashes for spotipylist-0.2.1-py3-none-any.whl
Algorithm Hash digest
SHA256 5cb10f45e14cc47a34c079454c094eba2c4061801bf6669996826b598aaec5c9
MD5 a4790461b0fe00e3cf45881c8aac258e
BLAKE2b-256 065c95283d43505a578ac5bccb5dd92dc5ce0f05d997dc21653b929d90bf76c5

See more details on using hashes here.

Provenance

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