mirror of
https://github.com/c0de-archive/spotipy.git
synced 2025-01-08 15:42:48 +00:00
Merge branch 'support_changing_playlist_details' of https://github.com/nathancoleman/spotipy into nathancoleman-support_changing_playlist_details
This commit is contained in:
commit
6b8ef3f4b0
@ -351,6 +351,7 @@ Spotipy authored by Paul Lamere (plamere) with contributions by:
|
|||||||
- Steve Winton // swinton
|
- Steve Winton // swinton
|
||||||
- Tim Balzer // timbalzer
|
- Tim Balzer // timbalzer
|
||||||
- corycorycory // corycorycory
|
- corycorycory // corycorycory
|
||||||
|
- Nathan Coleman // nathancoleman
|
||||||
|
|
||||||
License
|
License
|
||||||
=======
|
=======
|
||||||
|
38
examples/change_playlist_details.py
Normal file
38
examples/change_playlist_details.py
Normal file
@ -0,0 +1,38 @@
|
|||||||
|
|
||||||
|
# Modify the details of a playlist (name, public, collaborative)
|
||||||
|
|
||||||
|
import sys
|
||||||
|
|
||||||
|
import spotipy
|
||||||
|
import spotipy.util as util
|
||||||
|
|
||||||
|
if len(sys.argv) > 3:
|
||||||
|
username = sys.argv[1]
|
||||||
|
playlist_id = sys.argv[2]
|
||||||
|
name = sys.argv[3]
|
||||||
|
|
||||||
|
public = None
|
||||||
|
if len(sys.argv) > 4:
|
||||||
|
public = sys.argv[4].lower() == 'true'
|
||||||
|
|
||||||
|
collaborative = None
|
||||||
|
if len(sys.argv) > 5:
|
||||||
|
collaborative = sys.argv[5].lower() == 'true'
|
||||||
|
|
||||||
|
else:
|
||||||
|
print ("Usage: %s username playlist_id name [public collaborative]" %
|
||||||
|
(sys.argv[0]))
|
||||||
|
sys.exit()
|
||||||
|
|
||||||
|
scope = 'playlist-modify-public playlist-modify-private'
|
||||||
|
token = util.prompt_for_user_token(username, scope)
|
||||||
|
|
||||||
|
if token:
|
||||||
|
sp = spotipy.Spotify(auth=token)
|
||||||
|
sp.trace = False
|
||||||
|
results = sp.user_playlist_change_details(
|
||||||
|
username, playlist_id, name=name, public=public,
|
||||||
|
collaborative=collaborative)
|
||||||
|
print results
|
||||||
|
else:
|
||||||
|
print "Can't get token for", username
|
@ -3,7 +3,6 @@
|
|||||||
|
|
||||||
from __future__ import print_function
|
from __future__ import print_function
|
||||||
import sys
|
import sys
|
||||||
import base64
|
|
||||||
import requests
|
import requests
|
||||||
import json
|
import json
|
||||||
import time
|
import time
|
||||||
@ -11,6 +10,7 @@ import time
|
|||||||
''' A simple and thin Python library for the Spotify Web API
|
''' A simple and thin Python library for the Spotify Web API
|
||||||
'''
|
'''
|
||||||
|
|
||||||
|
|
||||||
class SpotifyException(Exception):
|
class SpotifyException(Exception):
|
||||||
def __init__(self, http_status, code, msg, headers=None):
|
def __init__(self, http_status, code, msg, headers=None):
|
||||||
self.http_status = http_status
|
self.http_status = http_status
|
||||||
@ -240,7 +240,6 @@ class Spotify(object):
|
|||||||
trid = self._get_id('artist', artist_id)
|
trid = self._get_id('artist', artist_id)
|
||||||
return self._get('artists/' + trid)
|
return self._get('artists/' + trid)
|
||||||
|
|
||||||
|
|
||||||
def artists(self, artists):
|
def artists(self, artists):
|
||||||
''' returns a list of artists given the artist IDs, URIs, or URLs
|
''' returns a list of artists given the artist IDs, URIs, or URLs
|
||||||
|
|
||||||
@ -251,8 +250,8 @@ class Spotify(object):
|
|||||||
tlist = [self._get_id('artist', a) for a in artists]
|
tlist = [self._get_id('artist', a) for a in artists]
|
||||||
return self._get('artists/?ids=' + ','.join(tlist))
|
return self._get('artists/?ids=' + ','.join(tlist))
|
||||||
|
|
||||||
def artist_albums(self, artist_id, album_type=None, country=None,
|
def artist_albums(self, artist_id, album_type=None, country=None, limit=20,
|
||||||
limit=20, offset=0):
|
offset=0):
|
||||||
''' Get Spotify catalog information about an artist's albums
|
''' Get Spotify catalog information about an artist's albums
|
||||||
|
|
||||||
Parameters:
|
Parameters:
|
||||||
@ -310,7 +309,8 @@ class Spotify(object):
|
|||||||
'''
|
'''
|
||||||
|
|
||||||
trid = self._get_id('album', album_id)
|
trid = self._get_id('album', album_id)
|
||||||
return self._get('albums/' + trid + '/tracks/', limit=limit, offset=offset)
|
return self._get('albums/' + trid + '/tracks/', limit=limit,
|
||||||
|
offset=offset)
|
||||||
|
|
||||||
def albums(self, albums):
|
def albums(self, albums):
|
||||||
''' returns a list of albums given the album IDs, URIs, or URLs
|
''' returns a list of albums given the album IDs, URIs, or URLs
|
||||||
@ -359,7 +359,8 @@ class Spotify(object):
|
|||||||
- limit - the number of items to return
|
- limit - the number of items to return
|
||||||
- offset - the index of the first item to return
|
- offset - the index of the first item to return
|
||||||
'''
|
'''
|
||||||
return self._get("users/%s/playlists" % user, limit=limit, offset=offset)
|
return self._get("users/%s/playlists" % user, limit=limit,
|
||||||
|
offset=offset)
|
||||||
|
|
||||||
def user_playlist(self, user, playlist_id=None, fields=None):
|
def user_playlist(self, user, playlist_id=None, fields=None):
|
||||||
''' Gets playlist of a user
|
''' Gets playlist of a user
|
||||||
@ -368,7 +369,7 @@ class Spotify(object):
|
|||||||
- playlist_id - the id of the playlist
|
- playlist_id - the id of the playlist
|
||||||
- fields - which fields to return
|
- fields - which fields to return
|
||||||
'''
|
'''
|
||||||
if playlist_id == None:
|
if playlist_id is None:
|
||||||
return self._get("users/%s/starred" % (user), fields=fields)
|
return self._get("users/%s/starred" % (user), fields=fields)
|
||||||
plid = self._get_id('playlist', playlist_id)
|
plid = self._get_id('playlist', playlist_id)
|
||||||
return self._get("users/%s/playlists/%s" % (user, plid), fields=fields)
|
return self._get("users/%s/playlists/%s" % (user, plid), fields=fields)
|
||||||
@ -387,7 +388,8 @@ class Spotify(object):
|
|||||||
'''
|
'''
|
||||||
plid = self._get_id('playlist', playlist_id)
|
plid = self._get_id('playlist', playlist_id)
|
||||||
return self._get("users/%s/playlists/%s/tracks" % (user, plid),
|
return self._get("users/%s/playlists/%s/tracks" % (user, plid),
|
||||||
limit=limit, offset=offset, fields=fields, market=market)
|
limit=limit, offset=offset, fields=fields,
|
||||||
|
market=market)
|
||||||
|
|
||||||
def user_playlist_create(self, user, name, public=True):
|
def user_playlist_create(self, user, name, public=True):
|
||||||
''' Creates a playlist for a user
|
''' Creates a playlist for a user
|
||||||
@ -400,6 +402,28 @@ class Spotify(object):
|
|||||||
data = {'name': name, 'public': public}
|
data = {'name': name, 'public': public}
|
||||||
return self._post("users/%s/playlists" % (user,), payload=data)
|
return self._post("users/%s/playlists" % (user,), payload=data)
|
||||||
|
|
||||||
|
def user_playlist_change_details(
|
||||||
|
self, user, playlist_id, name=None, public=None,
|
||||||
|
collaborative=None):
|
||||||
|
''' Changes a playlist's name and/or public/private state
|
||||||
|
|
||||||
|
Parameters:
|
||||||
|
- user - the id of the user
|
||||||
|
- playlist_id - the id of the playlist
|
||||||
|
- name - optional name of the playlist
|
||||||
|
- public - optional is the playlist public
|
||||||
|
- collaborative - optional is the playlist collaborative
|
||||||
|
'''
|
||||||
|
data = {}
|
||||||
|
if isinstance(name, basestring):
|
||||||
|
data['name'] = name
|
||||||
|
if isinstance(public, bool):
|
||||||
|
data['public'] = public
|
||||||
|
if isinstance(collaborative, bool):
|
||||||
|
data['collaborative'] = collaborative
|
||||||
|
return self._put("users/%s/playlists/%s" % (user, playlist_id),
|
||||||
|
payload=data)
|
||||||
|
|
||||||
def user_playlist_unfollow(self, user, playlist_id):
|
def user_playlist_unfollow(self, user, playlist_id):
|
||||||
''' Unfollows (deletes) a playlist for a user
|
''' Unfollows (deletes) a playlist for a user
|
||||||
|
|
||||||
@ -438,7 +462,8 @@ class Spotify(object):
|
|||||||
return self._put("users/%s/playlists/%s/tracks" % (user, plid),
|
return self._put("users/%s/playlists/%s/tracks" % (user, plid),
|
||||||
payload=payload)
|
payload=payload)
|
||||||
|
|
||||||
def user_playlist_reorder_tracks(self, user, playlist_id, range_start, insert_before,
|
def user_playlist_reorder_tracks(
|
||||||
|
self, user, playlist_id, range_start, insert_before,
|
||||||
range_length=1, snapshot_id=None):
|
range_length=1, snapshot_id=None):
|
||||||
''' Reorder tracks in a playlist
|
''' Reorder tracks in a playlist
|
||||||
|
|
||||||
@ -459,8 +484,8 @@ class Spotify(object):
|
|||||||
return self._put("users/%s/playlists/%s/tracks" % (user, plid),
|
return self._put("users/%s/playlists/%s/tracks" % (user, plid),
|
||||||
payload=payload)
|
payload=payload)
|
||||||
|
|
||||||
def user_playlist_remove_all_occurrences_of_tracks(self, user, playlist_id,
|
def user_playlist_remove_all_occurrences_of_tracks(
|
||||||
tracks, snapshot_id=None):
|
self, user, playlist_id, tracks, snapshot_id=None):
|
||||||
''' Removes all occurrences of the given tracks from the given playlist
|
''' Removes all occurrences of the given tracks from the given playlist
|
||||||
|
|
||||||
Parameters:
|
Parameters:
|
||||||
@ -479,8 +504,8 @@ class Spotify(object):
|
|||||||
return self._delete("users/%s/playlists/%s/tracks" % (user, plid),
|
return self._delete("users/%s/playlists/%s/tracks" % (user, plid),
|
||||||
payload=payload)
|
payload=payload)
|
||||||
|
|
||||||
def user_playlist_remove_specific_occurrences_of_tracks(self, user,
|
def user_playlist_remove_specific_occurrences_of_tracks(
|
||||||
playlist_id, tracks, snapshot_id=None):
|
self, user, playlist_id, tracks, snapshot_id=None):
|
||||||
''' Removes all occurrences of the given tracks from the given playlist
|
''' Removes all occurrences of the given tracks from the given playlist
|
||||||
|
|
||||||
Parameters:
|
Parameters:
|
||||||
@ -570,64 +595,73 @@ class Spotify(object):
|
|||||||
- after - ghe last artist ID retrieved from the previous request
|
- after - ghe last artist ID retrieved from the previous request
|
||||||
|
|
||||||
'''
|
'''
|
||||||
return self._get('me/following', type='artist', limit=limit, after=after)
|
return self._get('me/following', type='artist', limit=limit,
|
||||||
|
after=after)
|
||||||
|
|
||||||
def current_user_saved_tracks_delete(self, tracks=[]):
|
def current_user_saved_tracks_delete(self, tracks=None):
|
||||||
''' Remove one or more tracks from the current user's
|
''' Remove one or more tracks from the current user's
|
||||||
"Your Music" library.
|
"Your Music" library.
|
||||||
|
|
||||||
Parameters:
|
Parameters:
|
||||||
- tracks - a list of track URIs, URLs or IDs
|
- tracks - a list of track URIs, URLs or IDs
|
||||||
'''
|
'''
|
||||||
|
tlist = []
|
||||||
|
if tracks is not None:
|
||||||
tlist = [self._get_id('track', t) for t in tracks]
|
tlist = [self._get_id('track', t) for t in tracks]
|
||||||
return self._delete('me/tracks/?ids=' + ','.join(tlist))
|
return self._delete('me/tracks/?ids=' + ','.join(tlist))
|
||||||
|
|
||||||
def current_user_saved_tracks_contains(self, tracks=[]):
|
def current_user_saved_tracks_contains(self, tracks=None):
|
||||||
''' Check if one or more tracks is already saved in
|
''' Check if one or more tracks is already saved in
|
||||||
the current Spotify user’s “Your Music” library.
|
the current Spotify user’s “Your Music” library.
|
||||||
|
|
||||||
Parameters:
|
Parameters:
|
||||||
- tracks - a list of track URIs, URLs or IDs
|
- tracks - a list of track URIs, URLs or IDs
|
||||||
'''
|
'''
|
||||||
|
tlist = []
|
||||||
|
if tracks is not None:
|
||||||
tlist = [self._get_id('track', t) for t in tracks]
|
tlist = [self._get_id('track', t) for t in tracks]
|
||||||
return self._get('me/tracks/contains?ids=' + ','.join(tlist))
|
return self._get('me/tracks/contains?ids=' + ','.join(tlist))
|
||||||
|
|
||||||
|
def current_user_saved_tracks_add(self, tracks=None):
|
||||||
def current_user_saved_tracks_add(self, tracks=[]):
|
|
||||||
''' Add one or more tracks to the current user's
|
''' Add one or more tracks to the current user's
|
||||||
"Your Music" library.
|
"Your Music" library.
|
||||||
|
|
||||||
Parameters:
|
Parameters:
|
||||||
- tracks - a list of track URIs, URLs or IDs
|
- tracks - a list of track URIs, URLs or IDs
|
||||||
'''
|
'''
|
||||||
|
tlist = []
|
||||||
|
if tracks is not None:
|
||||||
tlist = [self._get_id('track', t) for t in tracks]
|
tlist = [self._get_id('track', t) for t in tracks]
|
||||||
return self._put('me/tracks/?ids=' + ','.join(tlist))
|
return self._put('me/tracks/?ids=' + ','.join(tlist))
|
||||||
|
|
||||||
def current_user_top_artists(self, limit=20, offset=0, time_range='medium_term'):
|
def current_user_top_artists(self, limit=20, offset=0,
|
||||||
|
time_range='medium_term'):
|
||||||
''' Get the current user's top artists
|
''' Get the current user's top artists
|
||||||
|
|
||||||
Parameters:
|
Parameters:
|
||||||
- limit - the number of entities to return
|
- limit - the number of entities to return
|
||||||
- offset - the index of the first entity to return
|
- offset - the index of the first entity to return
|
||||||
- time_range - Over what time frame are the affinities computed.
|
- time_range - Over what time frame are the affinities computed
|
||||||
Valid-values: short_term, medium_term, long_term
|
Valid-values: short_term, medium_term, long_term
|
||||||
'''
|
'''
|
||||||
return self._get('me/top/artists', time_range=time_range, limit=limit,offset=offset)
|
return self._get('me/top/artists', time_range=time_range, limit=limit,
|
||||||
|
offset=offset)
|
||||||
|
|
||||||
def current_user_top_tracks(self, limit=20, offset=0, time_range='medium_term'):
|
def current_user_top_tracks(self, limit=20, offset=0,
|
||||||
|
time_range='medium_term'):
|
||||||
''' Get the current user's top tracks
|
''' Get the current user's top tracks
|
||||||
|
|
||||||
Parameters:
|
Parameters:
|
||||||
- limit - the number of entities to return
|
- limit - the number of entities to return
|
||||||
- offset - the index of the first entity to return
|
- offset - the index of the first entity to return
|
||||||
- time_range - Over what time frame are the affinities computed.
|
- time_range - Over what time frame are the affinities computed
|
||||||
Valid-values: short_term, medium_term, long_term
|
Valid-values: short_term, medium_term, long_term
|
||||||
'''
|
'''
|
||||||
return self._get('me/top/tracks', time_range=time_range, limit=limit,offset=offset)
|
return self._get('me/top/tracks', time_range=time_range, limit=limit,
|
||||||
|
offset=offset)
|
||||||
|
|
||||||
|
def featured_playlists(self, locale=None, country=None, timestamp=None,
|
||||||
def featured_playlists(self, locale=None, country=None,
|
limit=20, offset=0):
|
||||||
timestamp=None, limit=20, offset = 0):
|
|
||||||
''' Get a list of Spotify featured playlists
|
''' Get a list of Spotify featured playlists
|
||||||
|
|
||||||
Parameters:
|
Parameters:
|
||||||
@ -650,7 +684,8 @@ class Spotify(object):
|
|||||||
items.
|
items.
|
||||||
'''
|
'''
|
||||||
return self._get('browse/featured-playlists', locale=locale,
|
return self._get('browse/featured-playlists', locale=locale,
|
||||||
country=country, timestamp=timestamp, limit=limit, offset=offset)
|
country=country, timestamp=timestamp, limit=limit,
|
||||||
|
offset=offset)
|
||||||
|
|
||||||
def new_releases(self, country=None, limit=20, offset=0):
|
def new_releases(self, country=None, limit=20, offset=0):
|
||||||
''' Get a list of new album releases featured in Spotify
|
''' Get a list of new album releases featured in Spotify
|
||||||
@ -665,8 +700,8 @@ class Spotify(object):
|
|||||||
(the first object). Use with limit to get the next set of
|
(the first object). Use with limit to get the next set of
|
||||||
items.
|
items.
|
||||||
'''
|
'''
|
||||||
return self._get('browse/new-releases', country=country,
|
return self._get('browse/new-releases', country=country, limit=limit,
|
||||||
limit=limit, offset=offset)
|
offset=offset)
|
||||||
|
|
||||||
def categories(self, country=None, locale=None, limit=20, offset=0):
|
def categories(self, country=None, locale=None, limit=20, offset=0):
|
||||||
''' Get a list of new album releases featured in Spotify
|
''' Get a list of new album releases featured in Spotify
|
||||||
@ -687,7 +722,8 @@ class Spotify(object):
|
|||||||
return self._get('browse/categories', country=country, locale=locale,
|
return self._get('browse/categories', country=country, locale=locale,
|
||||||
limit=limit, offset=offset)
|
limit=limit, offset=offset)
|
||||||
|
|
||||||
def category_playlists(self, category_id=None, country=None, limit=20, offset = 0):
|
def category_playlists(self, category_id=None, country=None, limit=20,
|
||||||
|
offset=0):
|
||||||
''' Get a list of new album releases featured in Spotify
|
''' Get a list of new album releases featured in Spotify
|
||||||
|
|
||||||
Parameters:
|
Parameters:
|
||||||
@ -702,11 +738,11 @@ class Spotify(object):
|
|||||||
(the first object). Use with limit to get the next set of
|
(the first object). Use with limit to get the next set of
|
||||||
items.
|
items.
|
||||||
'''
|
'''
|
||||||
return self._get('browse/categories/' + category_id + '/playlists', country=country,
|
return self._get('browse/categories/' + category_id + '/playlists',
|
||||||
limit=limit, offset=offset)
|
country=country, limit=limit, offset=offset)
|
||||||
|
|
||||||
def recommendations(self, seed_artists=[], seed_genres=[], seed_tracks=[],
|
def recommendations(self, seed_artists=None, seed_genres=None,
|
||||||
limit = 20, country=None, **kwargs):
|
seed_tracks=None, limit=20, country=None, **kwargs):
|
||||||
''' Get a list of recommended tracks for one to five seeds.
|
''' Get a list of recommended tracks for one to five seeds.
|
||||||
|
|
||||||
Parameters:
|
Parameters:
|
||||||
@ -739,9 +775,10 @@ class Spotify(object):
|
|||||||
if country:
|
if country:
|
||||||
params['market'] = country
|
params['market'] = country
|
||||||
|
|
||||||
for attribute in ["acousticness", "danceability", "duration_ms", "energy",
|
for attribute in ["acousticness", "danceability", "duration_ms",
|
||||||
"instrumentalness", "key", "liveness", "loudness", "mode", "popularity",
|
"energy", "instrumentalness", "key", "liveness",
|
||||||
"speechiness", "tempo", "time_signature", "valence"]:
|
"loudness", "mode", "popularity", "speechiness",
|
||||||
|
"tempo", "time_signature", "valence"]:
|
||||||
for prefix in ["min_", "max_", "target_"]:
|
for prefix in ["min_", "max_", "target_"]:
|
||||||
param = prefix + attribute
|
param = prefix + attribute
|
||||||
if param in kwargs:
|
if param in kwargs:
|
||||||
@ -787,15 +824,15 @@ class Spotify(object):
|
|||||||
fields = id.split(':')
|
fields = id.split(':')
|
||||||
if len(fields) >= 3:
|
if len(fields) >= 3:
|
||||||
if type != fields[-2]:
|
if type != fields[-2]:
|
||||||
self._warn('expected id of type ' + type + ' but found type ' \
|
self._warn('expected id of type %s but found type %s %s',
|
||||||
+ fields[2] + " " + id)
|
type, fields[-2], id)
|
||||||
return fields[-1]
|
return fields[-1]
|
||||||
fields = id.split('/')
|
fields = id.split('/')
|
||||||
if len(fields) >= 3:
|
if len(fields) >= 3:
|
||||||
itype = fields[-2]
|
itype = fields[-2]
|
||||||
if type != itype:
|
if type != itype:
|
||||||
self._warn('expected id of type ' + type + ' but found type ' \
|
self._warn('expected id of type %s but found type %s %s',
|
||||||
+ itype + " " + id)
|
type, itype, id)
|
||||||
return fields[-1]
|
return fields[-1]
|
||||||
return id
|
return id
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user