Skip to main content

Transfer Playlists from YouTube Music to Spotify

Project description

YouTube Music To Spotify

An open-source app for effortlessly transferring playlists from YouTube Music to Spotify.

Features

  • No limit on size of playlist
  • Support public playlists
  • Support private playlists
  • Auto create or update playlist if it already exists
  • Use fuzzy search to find the best match
  • Copy playlist thumbnail from youtube to spotify
  • Copy playlist description from youtube to spotify
  • Limit number of songs to be imported in the playlist
  • Dry run mode to test without adding to spotify

Setup

Spotify Developer Account

Why?

By setting up a Developer account and creating your own credentials (like keys), you are ensuring that the app connects to your account in a safe way without sharing your login details with anyone. It gives you full control over what the app can access and helps keep your Spotify account secure.

  1. Create a new app: https://developer.spotify.com/dashboard
  2. Set "Redirect URI" to http://localhost:8888/callback Spotify create new app
  3. Copy the "Client ID" and "Client Secret" to use later Spotify settings Spotify credentials
  4. Copy the "User ID" from your Spotify account: https://www.spotify.com/in-en/account/profile/ Spotify username

Installation

Download the latest version from the releases page.

[!NOTE]
Windows: Windows Defender may interrupt the app from running. Click on more info and allow the program to run.

Linux: You need to run the app from terminal, if you want the to know the progress of the transfer.

Using pip or pipx:

PyPI - Version PyPI - Downloads

If you have Python installed, you can install the app using pipx (recommended) or pip.

pipx install ytm2spt

or

pip install ytm2spt

After installation, you can run the app using the command ytm2spt.

[!CAUTION]
While syncing into an existing spotify playlist, first all the songs from Stopify playlist will be deleted and then the all the songs from YouTube Music playlist will be copied.

Spotify Settings

When you run the executable, you will be prompted to enter your Spotify credentials.

Spotify Settings

Youtube Settings

If you click on "Private Playlist", you will be prompted to enter get your Youtube OAuth credentials if not already set.

Youtube Settings

[!TIP]
If you find this project useful or interesting, please consider giving it a 🌟star! It helps others discover it too!


GUI

Python3 is required to run the app. You can download it from python.org for Windows.

Install Dependencies

pip install .

Run the App

python ytm2spt.py

CLI

Setting Environment Variables Linux and Mac

  1. Rename the file .env.sample to .env
  2. Edit the file by adding your credentials
  3. Run the following command to set your environment variable: source .env

Setting Environment Variables (Windows)

  1. Edit env.bat file by adding your credentials in these lines
    set SPOTIFY_USER_ID=<your_user_id>
    set SPOTIFY_CLIENT_ID=<your_client_id>
    set SPOTIFY_CLIENT_SECRET=<your_client_secret>
    
  2. Run the batch file to set your environment variable:
    env.bat
    

[!NOTE]
If the environment variables are not set, you may need to restart your terminal or IDE.

Install Dependencies

pip install -r requirements.txt

Youtube OAuth (Only for private playlists)

Run the following command to login to your Youtube account and save the credentials to ytmusicapi-oauth.json

ytmusicapi-oauth

Usage

$ source .env
$ ytm2spt -h
usage: ytm2spt [-h] -yt YOUTUBE_URL_OR_ID
               [-sp SPOTIFY_URL_OR_ID | -spname SPOTIFY_PLAYLIST_NAME]
               [-ytauth YOUTUBE_OAUTH_JSON]
               [-n | -d] [-l LIMIT]

options:
  -h, --help            show this help message and exit
  -yt YOUTUBE_URL_OR_ID, --youtube-url-or-id YOUTUBE_URL_OR_ID
                        Youtube Playlist URL or ID
  -sp SPOTIFY_URL_OR_ID, --spotify-url-or-id SPOTIFY_URL_OR_ID
                        Spotify Playlist URL or ID
  -spname SPOTIFY_PLAYLIST_NAME, --spotify-playlist-name SPOTIFY_PLAYLIST_NAME
                        Spotify Playlist Name (Default: Youtube Playlist Name)
  -ytauth YOUTUBE_OAUTH_JSON, --youtube-oauth-json YOUTUBE_OAUTH_JSON
                        Youtube OAuth JSON filepath (run 'ytmusicapi-oauth')
  -n, --create-new      Force create a new playlist
  -d, --dryrun          Do not add to Spotify
  -l LIMIT, --limit LIMIT
                        Limit the number of songs to fetch
$ ytmusicapi-oauth -h
usage: ytmusicapi-oauth [-h] [-b] [file]

positional arguments:
  file                file path to store the json (Default: ytmusic-oauth.json)

options:
  -h, --help          show this help message and exit
  -b, --open-browser  open browser for OAuth login (Default: True)

Examples

Sample Playlist: Pop Certified (YouTube Music to Spotify)

# Pass any link containing a youtube playlist ID
# Sets same name as youtube playlist
$ python ytm2spt.py -yt "https://music.youtube.com/playlist?list=RDCLAK5uy_lBNUteBRencHzKelu5iDHwLF6mYqjL-JU"

# Pass just the youtube playlist ID
# Set a custom name for the playlist
$ python ytm2spt.py -yt "CLAK5uy_lBNUteBRencHzKelu5iDHwLF6mYqjL-JU" -spname "Pop Certified"

# Pass link of a private youtube playlist
# Provide the path to the oauth.json file
$ python ytm2spt.py -yt "https://music.youtube.com/playlist?list=PLz96m0PSfi9p8ABcEcUlSMVmz7sN-IEFu" -ytauth "oauth.json"

# Pass an existing spotify playlist URL or ID
# Limit the number of songs to fetch
# Dry run mode
$ python ytm2spt.py -yt "CLAK5uy_lBNUteBRencHzKelu5iDHwLF6mYqjL-JU" -sp "https://open.spotify.com/playlist/6DyIxXHMwuEMbsfPTIr9C8" -l 10 -d

# Pass even the URL of video playing from playlist
# Force create a new playlist
$ python ytm2spt.py -yt "https://www.youtube.com/watch?v=RlPNh_PBZb4&list=RDCLAK5uy_lBNUteBRencHzKelu5iDHwLF6mYqjL-JU" -n

Build an Executable

Note: This is only required if you want to build the executable yourself. This is not necessary if you just need to run the app directly using Python.

Requirements:

  • C Compiler (gcc, clang)
  • patchelf (Linux only)
  • python3-devel or similar package in your OS
pip install -r requirements-dev.txt
nuitka ytm2spt.py

[!NOTE]
Forked from @edgarh22's Youtube-to-Spotify-Archiver.

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

ytm2spt-1.1.1.tar.gz (322.3 kB view details)

Uploaded Source

Built Distribution

ytm2spt-1.1.1-py3-none-any.whl (26.6 kB view details)

Uploaded Python 3

File details

Details for the file ytm2spt-1.1.1.tar.gz.

File metadata

  • Download URL: ytm2spt-1.1.1.tar.gz
  • Upload date:
  • Size: 322.3 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.12.8

File hashes

Hashes for ytm2spt-1.1.1.tar.gz
Algorithm Hash digest
SHA256 7da64e8fdde75d0f3c3d24e950a601788d788fee6915f7769c8f91c03da5494b
MD5 cad06d35af4e516b6c849baac156919f
BLAKE2b-256 d583e8bd9d6e1594be1e8a33172ff630b7332160e7b89cf6a0cbe125de1fe058

See more details on using hashes here.

Provenance

The following attestation bundles were made for ytm2spt-1.1.1.tar.gz:

Publisher: build.yaml on abhishekmj303/ytm2spt

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file ytm2spt-1.1.1-py3-none-any.whl.

File metadata

  • Download URL: ytm2spt-1.1.1-py3-none-any.whl
  • Upload date:
  • Size: 26.6 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.12.8

File hashes

Hashes for ytm2spt-1.1.1-py3-none-any.whl
Algorithm Hash digest
SHA256 0e75ce0665683604801eee7c111d1ba600cd7b79a400e3f96bf0c8b139b8901a
MD5 964e328c81d55dc871c502142362b47c
BLAKE2b-256 542f78e6da3763f23dad1e7ba5663724c5298013bdc5c570597d7c44bf9f7126

See more details on using hashes here.

Provenance

The following attestation bundles were made for ytm2spt-1.1.1-py3-none-any.whl:

Publisher: build.yaml on abhishekmj303/ytm2spt

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

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