Welcome to the Spotify to YouTube Music Playlist Migration Tool, a project designed to seamlessly transfer playlists from Spotify to YouTube Music using Python.
This project serves as an educational endeavor to explore the functionalities of Spotify's API and YouTube Music's API while honing Python skills. Although still in its developmental phase, the tool currently offers the following features:
- Spotify Authentication: Securely authenticates with Spotify.
- Playlist Retrieval: Fetches all user playlists from Spotify, including public, private, and collaborative ones.
- Local Storage: Stores playlists locally in a pickled migrator object for seamless migration.
- YouTube Authentication: Authenticates with YouTube for playlist migration.
- Migration Process: Transfers playlists from Spotify to YouTube Music, attempting to maintain song order and state across runs.
- Song Selection Algorithm: Utilizes a rudimentary algorithm to search YouTube Music for songs, based on the song and artist name.
- State Management: Capable of resuming from failures or interruptions by storing and retrieving current migration state locally.
This project is managed using Poetry. To install the necessary dependencies, run:
poetry install
To use the Spotify implementation, you need to obtain access credentials for your application following the steps documented here. Prior to running the script, set the following environment variables:
export SPOTIPY_CLIENT_ID='your-spotify-client-id'
export SPOTIPY_CLIENT_SECRET='your-spotify-client-secret'
export SPOTIPY_REDIRECT_URI='your-app-redirect-url'
For YouTube Music, follow the steps outlined here to authorize your application for OAuth use. This will generate an oauth.json file, which the code references. Run the following command once:
ytmusicapi oauth
To execute the script, use:
python main.py
The project is designed to resume from failure or interruption by storing the current state in a pickled file locally. It operates in two states:
- State: None: Playlist metadata needs to be fetched from Spotify. The script won't proceed until all playlists are processed in a single run.
- State: Populated: Spotify playlists are saved, and migration is underway. If errors occur, they are logged, and migration failures are recorded.
To delete the state, remove the migrator_data.db
file.
- Due to differences between Spotify and YouTube Music, a 1:1 mapping isn't guaranteed.
- The song selection algorithm may not be optimal for all cases, but it works for most scenarios.
- YouTube Music has playlist creation limits, which may affect the migration process.
Development tasks are managed with Poetry:
- Run code formatter (Black):
poetry run black .
- Run type check (PyType):
poetry run pytype
- Run tests (pytest):
poetry run pytest
- Run autoflake (removes unused imports):
autoflake --remove-unused-variables --remove-all-unused-imports --in-place --recursive service dao model adaptor tests
Feel free to reach out with questions or contribute through pull requests for new features or improvements. Your feedback is highly valued.