Learn R Programming

spotifyr

Overview

spotifyr is an R wrapper for pulling track audio features and other information from Spotify’s Web API in bulk. By automatically batching API requests, it allows you to enter an artist’s name and retrieve their entire discography in seconds, along with Spotify’s audio features and track/album popularity metrics. You can also pull song and playlist information for a given Spotify User (including yourself!).

Installation

CRAN version 2.2.3 (recommended)

install.packages('spotifyr')

Development version

devtools::install_github('charlie86/spotifyr')

Authentication

First, set up a Dev account with Spotify to access their Web API here. This will give you your Client ID and Client Secret. Once you have those, you can pull your access token into R with get_spotify_access_token().

The easiest way to authenticate is to set your credentials to the System Environment variables SPOTIFY_CLIENT_ID and SPOTIFY_CLIENT_SECRET. The default arguments to get_spotify_access_token() (and all other functions in this package) will refer to those. Alternatively, you can set them manually and make sure to explicitly refer to your access token in each subsequent function call.

Sys.setenv(SPOTIFY_CLIENT_ID = 'xxxxxxxxxxxxxxxxxxxxx')
Sys.setenv(SPOTIFY_CLIENT_SECRET = 'xxxxxxxxxxxxxxxxxxxxx')

access_token <- get_spotify_access_token()

Authorization Code Flow

For certain functions and applications, you’ll need to log in as a Spotify user. To do this, your Spotify Developer application needs to have a callback url. You can set this to whatever you want that will work with your application, but a good default option is http://localhost:1410/ (see image below). For more information on authorization, visit the offical Spotify Developer Guide.

Usage

What Was the Beatles’ Favorite Key?

library(spotifyr)
beatles <- get_artist_audio_features('the beatles')
library(dplyr)
library(purrr)
library(knitr)

beatles %>% 
    count(key_mode, sort = TRUE) %>% 
    head(5) %>% 
    kable()
key_moden
D major115
C major111
G major90
A major80
E major68

Get your most recently played tracks

library(lubridate)
#> Warning: package 'lubridate' was built under R version 4.1.1

get_my_recently_played(limit = 5) %>% 
    mutate(
        artist.name = map_chr(track.artists, function(x) x$name[1]),
        played_at = as_datetime(played_at)
        ) %>% 
    select(
      all_of(c("track.name", "artist.name", "track.album.name", "played_at"))
      ) %>% 
    kable()
track.nameartist.nametrack.album.nameplayed_at
Look For Me (I’ll Be Around)Neko CaseBlacklisted2021-11-01 17:16:12
Don’t Forget MeNeko CaseMiddle Cyclone2021-11-01 17:12:50
Magpie to the MorningNeko CaseThe Worse Things Get, The Harder I Fight, The Harder I Fight, The More I Love You (Deluxe Edition)2021-11-01 17:09:42
Margaret vs. PaulineNeko CaseFox Confessor Brings The Flood (Bonus Track Version)2021-11-01 17:06:45
Runnin’ Out Of FoolsNeko CaseBlacklisted2021-11-01 17:03:52

Find Your All Time Favorite Artists

get_my_top_artists_or_tracks(type = 'artists', 
                             time_range = 'long_term', 
                             limit = 5) %>% 
    select(.data$name, .data$genres) %>% 
    rowwise %>% 
    mutate(genres = paste(.data$genres, collapse = ', ')) %>% 
    ungroup %>% 
    kable()
namegenres
Japanese Breakfastart pop, eugene indie, indie pop, philly indie
Balthazarbelgian indie, belgian rock, dutch indie, ghent indie
Haley Bonarmelancholia, stomp and holler
Angus & Julia Stoneaustralian indie folk, indie folk, stomp and holler
Buildings Breedingindie fuzzpop

Find your favorite tracks at the moment

get_my_top_artists_or_tracks(type = 'tracks', 
                             time_range = 'short_term', 
                             limit = 5) %>% 
    mutate(
        artist.name = map_chr(artists, function(x) x$name[1])
        ) %>% 
    select(name, artist.name, album.name) %>% 
    kable()
nameartist.namealbum.name
Can’t Walk That BackTristenCan’t Walk That Back
You’re Too WeirdFruit BatsTripper
California (All the Way)LunaBewitched
Don’t Blame Your Daughter (Diamonds)The CardigansSuper Extra Gravity (Remastered)
Born In The ’70sFruit BatsSpelled In Bones

What’s the most joyful Joy Division song?

My favorite audio feature has to be “valence,” a measure of musical positivity.

joy <- get_artist_audio_features('joy division')
joy %>% 
    arrange(-valence) %>% 
    select(.data$track_name, .data$valence) %>% 
    head(5) %>% 
    kable()
track_namevalence
Passover - 2020 Digital Master0.946
Passover - 2007 Remaster0.941
Colony - 2020 Digital Master0.829
Colony - 2007 Remaster0.808
Atrocity Exhibition - 2020 Digital Master0.790

Now if only there was some way to plot joy…

Joyplot of the emotional rollercoasters that are Joy Division’s albums

library(ggplot2)
library(ggridges)

ggplot(
    joy, 
    aes(x = valence, y = album_name)
    ) + 
geom_density_ridges() + 
theme_ridges() +
labs(title = "Joyplot of Joy Division's joy distributions", 
     subtitle = "Based on valence pulled from Spotify's Web API with spotifyr")

Dope Stuff Other People Have Done with spotifyr

The coolest thing about making this package has definitely been seeing all the awesome stuff other people have done with it. Here are a few examples:

Exploring the Spotify API with R: A tutorial for beginners, by a beginner, Mia Smith

Blue Christmas: A data-driven search for the most depressing Christmas song, Caitlin Hudon

Sente-se triste quando ouve “Amar pelos dois”? Não é o único (Do you feel sad when you hear “Love for both?” You’re not alone), Rui Barros, Rádio Renascença

Using Data to Find the Angriest Death Grips Song, Evan Oppenheimer

Hierarchical clustering of David Bowie records, Alyssa Goldberg

tayloR, Simran Vatsa

Code of Conduct

Please note that the spotifyr project is released with a Contributor Code of Conduct. By contributing to this project, you agree to abide by its terms.

Copy Link

Version

Install

install.packages('spotifyr')

Monthly Downloads

1,310

Version

2.2.4

License

MIT + file LICENSE

Issues

Pull Requests

Stars

Forks

Maintainer

Daniel Antal

Last Published

December 15th, 2022

Functions in spotifyr (2.2.4)

get_album_tracks

Get Spotify catalog information about an album’s tracks. Optional parameters can be used to limit the number of tracks returned.
get_artist_albums

Get Spotify catalog information for multiple artists identified by their Spotify IDs.
get_my_currently_playing

Get the object currently being played on the user’s Spotify account.
get_my_current_playback

Get information about the user’s current playback state, including track, track progress, and active device.
get_artist_audio_features

Get Audio Features For Artists' Discography
get_artist

Get Spotify catalog information for a single artist identified by their unique Spotify ID.
get_my_recently_played

Get Current User's Recently Played Tracks
get_albums

Get Spotify catalog information for multiple albums identified by their Spotify IDs.
get_my_saved_albums

Get Current User's Saved Albums
get_artists

Get Spotify catalog information for multiple artists identified by their Spotify IDs.
get_artist_top_tracks

Get Spotify catalog information about an artist’s top tracks by country.
get_featured_playlists

Get list of Spotify featured playlists
get_category_playlists

Get a list of Spotify playlists tagged with a particular category
get_recommendations_all

Get recommendations for unlimited vector of track IDs
get_label_artists

Search for artists by label
get_genre_artists

Search for Artists by Genre
get_playlist_tracks

Get Details of User Playlist Tracks.
get_recommendations

Create a playlist-style listening experience based on seed artists, tracks and genres.
seek_to_position

Seeks to the given position in the user’s currently playing track.
search_spotify

Search for an Item
get_my_saved_tracks

Get User's Saved Tracks
get_my_devices

Get information about a user’s available devices.
get_my_followed_artists

Get My Followed Artists
get_my_top_artists_or_tracks

Get User’s Top Artists or Tracks
get_shows

Get Spotify catalog information for multiple shows identified by their Spotify IDs.
get_spotify_access_token

Get Spotify Access Token
get_spotify_authorization_code

Get Spotify Authorization Code
%>%

Pipe operator
set_my_repeat_mode

Set User Playback Mode
pitch_class_lookup

Pitch class notation lookup
get_track

Get Spotify catalog information for a single track identified by its unique Spotify ID.
get_user_playlists

Get List of User Playlists
validate_parameters

Assertion for Correct API Requests.
get_user_profile

Get User Public Profile Information
validate_position_ms

validate position_ms parameter
get_related_artists

Get Spotify catalog information about artists similar to a given artist. Similarity is based on analysis of the Spotify community’s listening history.
get_tracks

Get Spotify catalog information for a single track identified by its unique Spotify ID.
get_user_audio_features

Get User Playlist Audio Features
validate_state

validate state parameter
set_my_volume

Set User Device Volume
validate_type_artist_or_user

Validate type paramter for 'artists' or 'user'.
validate_time_range

validate time_range parameter
get_track_audio_analysis

Get a detailed audio analysis for a single track identified by its unique Spotify ID.
get_playlist_cover_image

Get Image Associated with Playlist
get_playlist_audio_features

Get Features and Popularity of Playlists on Spotify
get_track_audio_features

Get audio features of tracks
get_category

Get a single category used to tag items
get_categories

Get a list of Spotify categories
start_my_playback

Skips to previous track in the user’s queue.
remove_tracks_from_playlist

Remove Tracks from User’s Playlist
spotifyr

spotifyr package
scopes

Valid Authorization Scopes
get_my_playlists

Get List of My Playlists
get_new_releases

Get new releases
get_my_profile

Get User Profile Information
skip_my_playback

Skips to Next Track
skip_my_playback_previous

Skips to previous track in the user’s queue.
validate_country

Validate country parameter
validate_include_meta_info

Validate include_meta_info parameter
get_show

Get Spotify catalog information for a single show.
toggle_my_shuffle

Toggle shuffle on or off for user’s playback.
get_show_episodes

Get Spotify catalog information about an show's episodes. Optional parameters can be used to limit the number of episodes returned.
get_playlist

Get User Playlist
validate_limit

Validate limit parameter
tidy

Tidy a Playlist
validate_locale

Validate locale parameter
pause_my_playback

Pause Playback
transfer_my_playback

Transfer playback to a new device and determine if it should start playing.
is_uri

Check if a string matches the pattern of a Spotify URI
unfollow_playlist

Remove Current User from Followers of Playlist.
validate_market

Validate market parameter
validate_offset

Validate offset parameter
validate_type_artists_or_tracks

Validate type paramter for 'artists' or 'tracks'
validate_volume_percent

Validate volume percent parameter
verify_result

Verify API Result
add_tracks_to_playlist

Add Tracks to User’s Playlist
follow_playlist

Add Current User to Followers of Playlist.
check_users_following

Check if Users Follow a Playlist
get_album

Get Spotify catalog information for a single album.
create_playlist

Create Playlist for User
check_me_following

Check Me Following
dedupe_album_names

Remove duplicate album names
change_playlist_details

Change a playlist’s name and public/private state. (The user must, of course, own the playlist.)
follow_artists_or_users

Add Current User as Follower Artists or Other Users