From 4de300112d26aede7cfada9a5841231e1220843f Mon Sep 17 00:00:00 2001 From: Niko Date: Sun, 6 Oct 2024 21:37:22 +0200 Subject: [PATCH 1/4] use newer string formatters (https://pyformat.info) --- CHANGELOG.md | 1 + docs/index.rst | 2 +- examples/artist_albums.py | 4 +- examples/artist_discography.py | 12 +++--- examples/artist_recommendations.py | 3 +- examples/my_playlists.py | 2 +- examples/show_my_saved_tracks.py | 2 +- examples/user_playlists_contents.py | 4 +- examples/user_public_playlists.py | 8 +--- spotipy/cache_handler.py | 7 ++-- spotipy/client.py | 11 +++--- spotipy/oauth2.py | 50 ++++++++++++------------ tests/integration/user_endpoints/test.py | 4 +- 13 files changed, 50 insertions(+), 60 deletions(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index cab0c577..01a422dd 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -18,6 +18,7 @@ Add your changes below. - Added custom `urllib3.Retry` class for printing a warning when a rate/request limit is reached. - Added `personalized_playlist.py`, `track_recommendations.py`, and `audio_features_analysis.py` to `/examples`. - Discord badge in README +- Use newer string formatters (https://pyformat.info) ### Fixed - Audiobook integration tests diff --git a/docs/index.rst b/docs/index.rst index c7ef2bc8..beaae0e8 100644 --- a/docs/index.rst +++ b/docs/index.rst @@ -145,7 +145,7 @@ class SpotifyClientCredentials that can be used to authenticate requests like so playlists = sp.user_playlists('spotify') while playlists: for i, playlist in enumerate(playlists['items']): - print("%4d %s %s" % (i + 1 + playlists['offset'], playlist['uri'], playlist['name'])) + print("{:4d} {} {}".format(i + 1 + playlists['offset'], playlist['uri'], playlist['name'])) if playlists['next']: playlists = sp.next(playlists) else: diff --git a/examples/artist_albums.py b/examples/artist_albums.py index c5cc7a6a..8ffcda3f 100644 --- a/examples/artist_albums.py +++ b/examples/artist_albums.py @@ -38,7 +38,7 @@ def show_artist_albums(artist): for album in albums: name = album['name'] if name not in seen: - logger.info('ALBUM: %s', name) + logger.info('ALBUM: {name}') seen.add(name) @@ -48,7 +48,7 @@ def main(): if artist: show_artist_albums(artist) else: - logger.error("Can't find artist: %s", artist) + logger.error(f"Can't find artist: {artist}") if __name__ == '__main__': diff --git a/examples/artist_discography.py b/examples/artist_discography.py index 84f9c268..21fafa0a 100644 --- a/examples/artist_discography.py +++ b/examples/artist_discography.py @@ -34,7 +34,7 @@ def show_album_tracks(album): results = sp.next(results) tracks.extend(results['items']) for i, track in enumerate(tracks): - logger.info('%s. %s', i + 1, track['name']) + logger.info(f'{i + 1}. {track["name"]}') def show_artist_albums(artist): @@ -44,21 +44,21 @@ def show_artist_albums(artist): while results['next']: results = sp.next(results) albums.extend(results['items']) - logger.info('Total albums: %s', len(albums)) + logger.info(f'Total albums: {len(albums)}') unique = set() # skip duplicate albums for album in albums: name = album['name'].lower() if name not in unique: - logger.info('ALBUM: %s', name) + logger.info(f'ALBUM: {name}') unique.add(name) show_album_tracks(album) def show_artist(artist): - logger.info('====%s====', artist['name']) - logger.info('Popularity: %s', artist['popularity']) + logger.info(f'===={artist["name"]}====') + logger.info(f'Popularity: {artist["popularity"]}') if len(artist['genres']) > 0: - logger.info('Genres: %s', ','.join(artist['genres'])) + logger.info('Genres: {}'.format(','.join(artist['genres']))) def main(): diff --git a/examples/artist_recommendations.py b/examples/artist_recommendations.py index 40a95a23..3ccabf42 100644 --- a/examples/artist_recommendations.py +++ b/examples/artist_recommendations.py @@ -31,8 +31,7 @@ def get_artist(name): def show_recommendations_for_artist(artist): results = sp.recommendations(seed_artists=[artist['id']]) for track in results['tracks']: - logger.info('Recommendation: %s - %s', track['name'], - track['artists'][0]['name']) + logger.info(f'Recommendation: {track["name"]} - {track["artists"][0]["name"]}') def main(): diff --git a/examples/my_playlists.py b/examples/my_playlists.py index 8c8e9be1..7a5f46c3 100644 --- a/examples/my_playlists.py +++ b/examples/my_playlists.py @@ -8,4 +8,4 @@ results = sp.current_user_playlists(limit=50) for i, item in enumerate(results['items']): - print("%d %s" % (i, item['name'])) + print(f"{i} {item['name']}") diff --git a/examples/show_my_saved_tracks.py b/examples/show_my_saved_tracks.py index ebff4fea..d606f06b 100644 --- a/examples/show_my_saved_tracks.py +++ b/examples/show_my_saved_tracks.py @@ -9,7 +9,7 @@ def show_tracks(results): for item in results['items']: track = item['track'] - print("%32.32s %s" % (track['artists'][0]['name'], track['name'])) + print(f"{track['artists'][0]['name']:>32.32} {track['name']}") sp = spotipy.Spotify(auth_manager=SpotifyOAuth(scope=scope)) diff --git a/examples/user_playlists_contents.py b/examples/user_playlists_contents.py index 9379a0b8..e5a8ee11 100644 --- a/examples/user_playlists_contents.py +++ b/examples/user_playlists_contents.py @@ -7,9 +7,7 @@ def show_tracks(results): for i, item in enumerate(results['items']): track = item['track'] - print( - " %d %32.32s %s" % - (i, track['artists'][0]['name'], track['name'])) + print(f" {i} {track['artists'][0]['name']:>32.32} {track['name']}") if __name__ == '__main__': diff --git a/examples/user_public_playlists.py b/examples/user_public_playlists.py index 2d7f64f2..0231f369 100644 --- a/examples/user_public_playlists.py +++ b/examples/user_public_playlists.py @@ -18,13 +18,7 @@ while playlists: for i, playlist in enumerate(playlists['items']): - print( - "%4d %s %s" % - (i + - 1 + - playlists['offset'], - playlist['uri'], - playlist['name'])) + print(f"{i + 1 + playlists['offset']:4d} {playlist['uri']} {playlist['name']}") if playlists['next']: playlists = sp.next(playlists) else: diff --git a/spotipy/cache_handler.py b/spotipy/cache_handler.py index 7ae94a23..413af453 100644 --- a/spotipy/cache_handler.py +++ b/spotipy/cache_handler.py @@ -83,9 +83,9 @@ def get_cached_token(self): except OSError as error: if error.errno == errno.ENOENT: - logger.debug("cache does not exist at: %s", self.cache_path) + logger.debug(f"cache does not exist at: {self.cache_path}") else: - logger.warning("Couldn't read cache at: %s", self.cache_path) + logger.warning(f"Couldn't read cache at: {self.cache_path}") return token_info @@ -95,8 +95,7 @@ def save_token_to_cache(self, token_info): f.write(json.dumps(token_info, cls=self.encoder_cls)) f.close() except OSError: - logger.warning('Couldn\'t write token to cache at: %s', - self.cache_path) + logger.warning(f"Couldn't write token to cache at: {self.cache_path}") class MemoryCacheHandler(CacheHandler): diff --git a/spotipy/client.py b/spotipy/client.py index 61924a55..e5b6cf8d 100644 --- a/spotipy/client.py +++ b/spotipy/client.py @@ -263,8 +263,8 @@ def _internal_call(self, method, url, payload, params): if self.language is not None: headers["Accept-Language"] = self.language - logger.debug('Sending %s to %s with Params: %s Headers: %s and Body: %r ', - method, url, args.get("params"), headers, args.get('data')) + logger.debug('Sending {} to {} with Params: {} Headers: {} and Body: {!r} '.format( + method, url, args.get("params"), headers, args.get('data'))) try: response = self._session.request( @@ -290,8 +290,9 @@ def _internal_call(self, method, url, payload, params): reason = None logger.error( - 'HTTP Error for %s to %s with Params: %s returned %s due to %s', - method, url, args.get("params"), response.status_code, msg + 'HTTP Error for {} to {} with Params: {} returned {} due to {}'.format( + method, url, args.get("params"), response.status_code, msg + ) ) raise SpotifyException( @@ -317,7 +318,7 @@ def _internal_call(self, method, url, payload, params): except ValueError: results = None - logger.debug('RESULTS: %s', results) + logger.debug(f'RESULTS: {results}') return results def _get(self, url, args=None, payload=None, **kwargs): diff --git a/spotipy/oauth2.py b/spotipy/oauth2.py index 4c0cd906..d102a2b3 100644 --- a/spotipy/oauth2.py +++ b/spotipy/oauth2.py @@ -240,8 +240,8 @@ def _request_access_token(self): ) logger.debug( - "sending POST request to %s with Headers: %s and Body: %r", - self.OAUTH_TOKEN_URL, headers, payload + "sending POST request to {} with Headers: {} and Body: {!r}".format( + self.OAUTH_TOKEN_URL, headers, payload) ) try: @@ -423,9 +423,9 @@ def _open_auth_url(self): auth_url = self.get_authorize_url() try: webbrowser.open(auth_url) - logger.info("Opened %s in your browser", auth_url) + logger.info(f"Opened {auth_url} in your browser") except webbrowser.Error: - logger.error("Please navigate here: %s", auth_url) + logger.error(f"Please navigate here: {auth_url}") def _get_auth_response_interactive(self, open_browser=False): if open_browser: @@ -434,8 +434,8 @@ def _get_auth_response_interactive(self, open_browser=False): else: url = self.get_authorize_url() prompt = ( - "Go to the following URL: {}\n" - "Enter the URL you were redirected to: ".format(url) + f"Go to the following URL: {url}\n" + "Enter the URL you were redirected to: " ) response = self._get_user_input(prompt) state, code = SpotifyOAuth.parse_auth_response_url(response) @@ -479,12 +479,11 @@ def get_auth_response(self, open_browser=None): if redirect_port: return self._get_auth_response_local_server(redirect_port) else: - logger.warning('Using `%s` as redirect URI without a port. ' - 'Specify a port (e.g. `%s:8080`) to allow ' + logger.warning(f'Using `{redirect_host}` as redirect URI without a port. ' + f'Specify a port (e.g. `{redirect_host}:8080`) to allow ' 'automatic retrieval of authentication code ' 'instead of having to copy and paste ' - 'the URL your browser is redirected to.', - redirect_host, redirect_host) + 'the URL your browser is redirected to.') return self._get_auth_response_interactive(open_browser=open_browser) @@ -533,8 +532,8 @@ def get_access_token(self, code=None, as_dict=True, check_cache=True): headers = self._make_authorization_headers() logger.debug( - "sending POST request to %s with Headers: %s and Body: %r", - self.OAUTH_TOKEN_URL, headers, payload + "sending POST request to {} with Headers: {} and Body: {!r}".format( + self.OAUTH_TOKEN_URL, headers, payload) ) try: @@ -563,8 +562,8 @@ def refresh_access_token(self, refresh_token): headers = self._make_authorization_headers() logger.debug( - "sending POST request to %s with Headers: %s and Body: %r", - self.OAUTH_TOKEN_URL, headers, payload + "sending POST request to {} with Headers: {} and Body: {!r}".format( + self.OAUTH_TOKEN_URL, headers, payload) ) try: @@ -755,9 +754,9 @@ def _open_auth_url(self, state=None): auth_url = self.get_authorize_url(state) try: webbrowser.open(auth_url) - logger.info("Opened %s in your browser", auth_url) + logger.info(f"Opened {auth_url} in your browser") except webbrowser.Error: - logger.error("Please navigate here: %s", auth_url) + logger.error(f"Please navigate here: {auth_url}") def _get_auth_response(self, open_browser=None): logger.info('User authentication requires interaction with your ' @@ -781,12 +780,11 @@ def _get_auth_response(self, open_browser=None): if redirect_port: return self._get_auth_response_local_server(redirect_port) else: - logger.warning('Using `%s` as redirect URI without a port. ' - 'Specify a port (e.g. `%s:8080`) to allow ' + logger.warning(f'Using `{redirect_host}` as redirect URI without a port. ' + f'Specify a port (e.g. `{redirect_host}:8080`) to allow ' 'automatic retrieval of authentication code ' 'instead of having to copy and paste ' - 'the URL your browser is redirected to.', - redirect_host, redirect_host) + 'the URL your browser is redirected to.') return self._get_auth_response_interactive(open_browser=open_browser) def _get_auth_response_local_server(self, redirect_port): @@ -890,8 +888,8 @@ def get_access_token(self, code=None, check_cache=True): headers = {"Content-Type": "application/x-www-form-urlencoded"} logger.debug( - "sending POST request to %s with Headers: %s and Body: %r", - self.OAUTH_TOKEN_URL, headers, payload + "sending POST request to {} with Headers: {} and Body: {!r}".format( + self.OAUTH_TOKEN_URL, headers, payload) ) try: @@ -921,8 +919,8 @@ def refresh_access_token(self, refresh_token): headers = {"Content-Type": "application/x-www-form-urlencoded"} logger.debug( - "sending POST request to %s with Headers: %s and Body: %r", - self.OAUTH_TOKEN_URL, headers, payload + "sending POST request to {} with Headers: {} and Body: {!r}".format( + self.OAUTH_TOKEN_URL, headers, payload) ) try: @@ -1174,9 +1172,9 @@ def _open_auth_url(self, state=None): auth_url = self.get_authorize_url(state) try: webbrowser.open(auth_url) - logger.info("Opened %s in your browser", auth_url) + logger.info(f"Opened {auth_url} in your browser") except webbrowser.Error: - logger.error("Please navigate here: %s", auth_url) + logger.error(f"Please navigate here: {auth_url}") def get_auth_response(self, state=None): """ Gets a new auth **token** with user interaction """ diff --git a/tests/integration/user_endpoints/test.py b/tests/integration/user_endpoints/test.py index fb1fbb21..19b952f8 100644 --- a/tests/integration/user_endpoints/test.py +++ b/tests/integration/user_endpoints/test.py @@ -586,7 +586,7 @@ def test_add_to_queue(self, mock_post): self.spotify.add_to_queue(test_uri) # Check if the correct endpoint is called - endpoint = "me/player/queue?uri=%s" % test_uri + endpoint = f"me/player/queue?uri={test_uri}" mock_post.assert_called_with(endpoint) def test_add_to_queue_with_device_id(self, mock_post): @@ -597,5 +597,5 @@ def test_add_to_queue_with_device_id(self, mock_post): self.spotify.add_to_queue(test_uri, device_id=device_id) # Check if the correct endpoint is called - endpoint = "me/player/queue?uri=%s&device_id=%s" % (test_uri, device_id) + endpoint = f"me/player/queue?uri={test_url}&device_id={device_id}" mock_post.assert_called_with(endpoint) From 51c22c129dc0673cf51f0f5da7818dadd94054a9 Mon Sep 17 00:00:00 2001 From: Niko Date: Sun, 6 Oct 2024 21:40:46 +0200 Subject: [PATCH 2/4] fix typo --- tests/integration/user_endpoints/test.py | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/tests/integration/user_endpoints/test.py b/tests/integration/user_endpoints/test.py index 19b952f8..030f0922 100644 --- a/tests/integration/user_endpoints/test.py +++ b/tests/integration/user_endpoints/test.py @@ -597,5 +597,5 @@ def test_add_to_queue_with_device_id(self, mock_post): self.spotify.add_to_queue(test_uri, device_id=device_id) # Check if the correct endpoint is called - endpoint = f"me/player/queue?uri={test_url}&device_id={device_id}" + endpoint = f"me/player/queue?uri={test_uri}&device_id={device_id}" mock_post.assert_called_with(endpoint) From 61bd0f9d70ebbc913897769bb3e298aaa43da4b7 Mon Sep 17 00:00:00 2001 From: Niko Date: Tue, 3 Dec 2024 13:35:28 +0100 Subject: [PATCH 3/4] went through the files again, additions from #1165 are also included --- examples/artist_albums.py | 7 ++----- examples/artist_discography.py | 5 +---- examples/artist_recommendations.py | 5 +---- examples/follow_playlist.py | 11 +++-------- spotipy/cache_handler.py | 12 ++++++------ spotipy/oauth2.py | 10 +++++----- 6 files changed, 18 insertions(+), 32 deletions(-) diff --git a/examples/artist_albums.py b/examples/artist_albums.py index 8ffcda3f..ce89b6eb 100644 --- a/examples/artist_albums.py +++ b/examples/artist_albums.py @@ -20,10 +20,7 @@ def get_args(): def get_artist(name): results = sp.search(q='artist:' + name, type='artist') items = results['artists']['items'] - if len(items) > 0: - return items[0] - else: - return None + return items[0] if items else None def show_artist_albums(artist): @@ -38,7 +35,7 @@ def show_artist_albums(artist): for album in albums: name = album['name'] if name not in seen: - logger.info('ALBUM: {name}') + logger.info(f'ALBUM: {name}') seen.add(name) diff --git a/examples/artist_discography.py b/examples/artist_discography.py index 21fafa0a..e691892b 100644 --- a/examples/artist_discography.py +++ b/examples/artist_discography.py @@ -20,10 +20,7 @@ def get_args(): def get_artist(name): results = sp.search(q='artist:' + name, type='artist') items = results['artists']['items'] - if len(items) > 0: - return items[0] - else: - return None + return items[0] if items else None def show_album_tracks(album): diff --git a/examples/artist_recommendations.py b/examples/artist_recommendations.py index 3ccabf42..d1af3ca8 100644 --- a/examples/artist_recommendations.py +++ b/examples/artist_recommendations.py @@ -22,10 +22,7 @@ def get_args(): def get_artist(name): results = sp.search(q='artist:' + name, type='artist') items = results['artists']['items'] - if len(items) > 0: - return items[0] - else: - return None + return items[0] if items else None def show_recommendations_for_artist(artist): diff --git a/examples/follow_playlist.py b/examples/follow_playlist.py index 6973468c..e6bba991 100644 --- a/examples/follow_playlist.py +++ b/examples/follow_playlist.py @@ -13,14 +13,9 @@ def get_args(): def main(): args = get_args() - - if args.playlist is None: - # Uses the Spotify Global Top 50 playlist - spotipy.Spotify(auth_manager=SpotifyOAuth()).current_user_follow_playlist( - '37i9dQZEVXbMDoHDwVN2tF') - - else: - spotipy.Spotify(auth_manager=SpotifyOAuth()).current_user_follow_playlist(args.playlist) + # Uses Lofi Girl playlist + playlist = args.playlist or '0vvXsWCC9xrXsKd4FyS8kM' + spotipy.Spotify(auth_manager=SpotifyOAuth()).current_user_follow_playlist(playlist) if __name__ == '__main__': diff --git a/spotipy/cache_handler.py b/spotipy/cache_handler.py index 413af453..ffe539f1 100644 --- a/spotipy/cache_handler.py +++ b/spotipy/cache_handler.py @@ -148,7 +148,7 @@ def save_token_to_cache(self, token_info): try: self.request.session['token_info'] = token_info except Exception as e: - logger.warning("Error saving token to cache: " + str(e)) + logger.warning(f"Error saving token to cache: {e}") class FlaskSessionCacheHandler(CacheHandler): @@ -173,7 +173,7 @@ def save_token_to_cache(self, token_info): try: self.session["token_info"] = token_info except Exception as e: - logger.warning("Error saving token to cache: " + str(e)) + logger.warning(f"Error saving token to cache: {e}") class RedisCacheHandler(CacheHandler): @@ -199,7 +199,7 @@ def get_cached_token(self): if token_info: return json.loads(token_info) except RedisError as e: - logger.warning('Error getting token from cache: ' + str(e)) + logger.warning(f"Error getting token from cache: {e}") return token_info @@ -207,7 +207,7 @@ def save_token_to_cache(self, token_info): try: self.redis.set(self.key, json.dumps(token_info)) except RedisError as e: - logger.warning('Error saving token to cache: ' + str(e)) + logger.warning(f"Error saving token to cache: {e}") class MemcacheCacheHandler(CacheHandler): @@ -231,11 +231,11 @@ def get_cached_token(self): if token_info: return json.loads(token_info.decode()) except MemcacheError as e: - logger.warning('Error getting token from cache' + str(e)) + logger.warning(f"Error getting token to cache: {e}") def save_token_to_cache(self, token_info): from pymemcache import MemcacheError try: self.memcache.set(self.key, json.dumps(token_info)) except MemcacheError as e: - logger.warning('Error saving token to cache' + str(e)) + logger.warning(f"Error saving token to cache: {e}") diff --git a/spotipy/oauth2.py b/spotipy/oauth2.py index d102a2b3..390151a0 100644 --- a/spotipy/oauth2.py +++ b/spotipy/oauth2.py @@ -240,7 +240,7 @@ def _request_access_token(self): ) logger.debug( - "sending POST request to {} with Headers: {} and Body: {!r}".format( + "Sending POST request to {} with Headers: {} and Body: {!r}".format( self.OAUTH_TOKEN_URL, headers, payload) ) @@ -532,7 +532,7 @@ def get_access_token(self, code=None, as_dict=True, check_cache=True): headers = self._make_authorization_headers() logger.debug( - "sending POST request to {} with Headers: {} and Body: {!r}".format( + "Sending POST request to {} with Headers: {} and Body: {!r}".format( self.OAUTH_TOKEN_URL, headers, payload) ) @@ -562,7 +562,7 @@ def refresh_access_token(self, refresh_token): headers = self._make_authorization_headers() logger.debug( - "sending POST request to {} with Headers: {} and Body: {!r}".format( + "Sending POST request to {} with Headers: {} and Body: {!r}".format( self.OAUTH_TOKEN_URL, headers, payload) ) @@ -888,7 +888,7 @@ def get_access_token(self, code=None, check_cache=True): headers = {"Content-Type": "application/x-www-form-urlencoded"} logger.debug( - "sending POST request to {} with Headers: {} and Body: {!r}".format( + "Sending POST request to {} with Headers: {} and Body: {!r}".format( self.OAUTH_TOKEN_URL, headers, payload) ) @@ -919,7 +919,7 @@ def refresh_access_token(self, refresh_token): headers = {"Content-Type": "application/x-www-form-urlencoded"} logger.debug( - "sending POST request to {} with Headers: {} and Body: {!r}".format( + "Sending POST request to {} with Headers: {} and Body: {!r}".format( self.OAUTH_TOKEN_URL, headers, payload) ) From 4b486f8f60fecd5a54bc7502f293c7f636bc2418 Mon Sep 17 00:00:00 2001 From: Niko Date: Fri, 13 Dec 2024 23:13:36 +0100 Subject: [PATCH 4/4] replace .format() with f strings --- docs/index.rst | 2 +- examples/artist_discography.py | 2 +- examples/track_recommendations.py | 7 ++---- spotipy/client.py | 19 ++++++---------- spotipy/exceptions.py | 5 +++-- spotipy/oauth2.py | 36 +++++++++++-------------------- 6 files changed, 26 insertions(+), 45 deletions(-) diff --git a/docs/index.rst b/docs/index.rst index beaae0e8..990205cb 100644 --- a/docs/index.rst +++ b/docs/index.rst @@ -145,7 +145,7 @@ class SpotifyClientCredentials that can be used to authenticate requests like so playlists = sp.user_playlists('spotify') while playlists: for i, playlist in enumerate(playlists['items']): - print("{:4d} {} {}".format(i + 1 + playlists['offset'], playlist['uri'], playlist['name'])) + print(f"{i + 1 + playlists['offset']:4d} {playlist['uri']} {playlist['name']}") if playlists['next']: playlists = sp.next(playlists) else: diff --git a/examples/artist_discography.py b/examples/artist_discography.py index e691892b..aeb3003b 100644 --- a/examples/artist_discography.py +++ b/examples/artist_discography.py @@ -55,7 +55,7 @@ def show_artist(artist): logger.info(f'===={artist["name"]}====') logger.info(f'Popularity: {artist["popularity"]}') if len(artist['genres']) > 0: - logger.info('Genres: {}'.format(','.join(artist['genres']))) + logger.info(f"Genres: {', '.join(artist['genres'])}") def main(): diff --git a/examples/track_recommendations.py b/examples/track_recommendations.py index 38cf4beb..6172e9b9 100644 --- a/examples/track_recommendations.py +++ b/examples/track_recommendations.py @@ -38,8 +38,5 @@ # Display the recommendations for i, track in enumerate(recommendations['tracks']): - print( - "{}. {} by {}" - .format(i+1, track['name'], ', ' - .join([artist['name'] for artist in track['artists']])) - ) + print(f"{i+1}. {track['name']} by " + f"{', '.join([artist['name'] for artist in track['artists']])}") diff --git a/spotipy/client.py b/spotipy/client.py index e5b6cf8d..77d1fb10 100644 --- a/spotipy/client.py +++ b/spotipy/client.py @@ -263,8 +263,8 @@ def _internal_call(self, method, url, payload, params): if self.language is not None: headers["Accept-Language"] = self.language - logger.debug('Sending {} to {} with Params: {} Headers: {} and Body: {!r} '.format( - method, url, args.get("params"), headers, args.get('data'))) + logger.debug(f"Sending {method} to {url} with Params: " + f"{args.get('params')} Headers: {headers} and Body: {args.get('data')!r}") try: response = self._session.request( @@ -289,11 +289,8 @@ def _internal_call(self, method, url, payload, params): msg = response.text or None reason = None - logger.error( - 'HTTP Error for {} to {} with Params: {} returned {} due to {}'.format( - method, url, args.get("params"), response.status_code, msg - ) - ) + logger.error(f"HTTP Error for {method} to {url} with Params: " + f"{args.get('params')} returned {response.status_code} due to {msg}") raise SpotifyException( response.status_code, @@ -2035,11 +2032,9 @@ def _is_uri(self, uri): def _search_multiple_markets(self, q, limit, offset, type, markets, total): if total and limit > total: limit = total - warnings.warn( - "limit was auto-adjusted to equal {} as it must not be higher than total".format( - total), - UserWarning, - ) + warnings.warn(f"limit was auto-adjusted to equal {total} " + f"as it must not be higher than total", + UserWarning) results = defaultdict(dict) item_types = [item_type + "s" for item_type in type.split(",")] diff --git a/spotipy/exceptions.py b/spotipy/exceptions.py index ba2d5f16..cacce9fd 100644 --- a/spotipy/exceptions.py +++ b/spotipy/exceptions.py @@ -16,8 +16,9 @@ def __init__(self, http_status, code, msg, reason=None, headers=None): self.headers = headers def __str__(self): - return 'http status: {}, code:{} - {}, reason: {}'.format( - self.http_status, self.code, self.msg, self.reason) + return (f"http status: {self.http_status}, " + f"code: {self.code} - {self.msg}, " + f"reason: {self.reason}") class SpotifyOauthError(SpotifyBaseException): diff --git a/spotipy/oauth2.py b/spotipy/oauth2.py index 431cebb7..c17b4e8f 100644 --- a/spotipy/oauth2.py +++ b/spotipy/oauth2.py @@ -217,10 +217,8 @@ def _request_access_token(self): self.client_id, self.client_secret ) - logger.debug( - "Sending POST request to {} with Headers: {} and Body: {!r}".format( - self.OAUTH_TOKEN_URL, headers, payload) - ) + logger.debug(f"Sending POST request to {self.OAUTH_TOKEN_URL} with Headers: " + f"{headers} and Body: {payload}") try: response = self._session.post( @@ -509,10 +507,8 @@ def get_access_token(self, code=None, as_dict=True, check_cache=True): headers = self._make_authorization_headers() - logger.debug( - "Sending POST request to {} with Headers: {} and Body: {!r}".format( - self.OAUTH_TOKEN_URL, headers, payload) - ) + logger.debug(f"Sending POST request to {self.OAUTH_TOKEN_URL} with Headers: " + f"{headers} and Body: {payload}") try: response = self._session.post( @@ -539,10 +535,8 @@ def refresh_access_token(self, refresh_token): headers = self._make_authorization_headers() - logger.debug( - "Sending POST request to {} with Headers: {} and Body: {!r}".format( - self.OAUTH_TOKEN_URL, headers, payload) - ) + logger.debug(f"Sending POST request to {self.OAUTH_TOKEN_URL} with Headers: " + f"{headers} and Body: {payload}") try: response = self._session.post( @@ -786,10 +780,8 @@ def _get_auth_response_interactive(self, open_browser=False): prompt = "Enter the URL you were redirected to: " else: url = self.get_authorize_url() - prompt = ( - "Go to the following URL: {}\n" - "Enter the URL you were redirected to: ".format(url) - ) + prompt = (f"Go to the following URL: {url}\n" + f"Enter the URL you were redirected to: ") response = self._get_user_input(prompt) state, code = self.parse_auth_response_url(response) if self.state is not None and self.state != state: @@ -865,10 +857,8 @@ def get_access_token(self, code=None, check_cache=True): headers = {"Content-Type": "application/x-www-form-urlencoded"} - logger.debug( - "Sending POST request to {} with Headers: {} and Body: {!r}".format( - self.OAUTH_TOKEN_URL, headers, payload) - ) + logger.debug(f"Sending POST request to {self.OAUTH_TOKEN_URL} with Headers: " + f"{headers} and Body: {payload}") try: response = self._session.post( @@ -896,10 +886,8 @@ def refresh_access_token(self, refresh_token): headers = {"Content-Type": "application/x-www-form-urlencoded"} - logger.debug( - "Sending POST request to {} with Headers: {} and Body: {!r}".format( - self.OAUTH_TOKEN_URL, headers, payload) - ) + logger.debug(f"Sending POST request to {self.OAUTH_TOKEN_URL} with Headers: " + f"{headers} and Body: {payload}") try: response = self._session.post(