mirror of
				https://github.com/JonasunderscoreJones/turbo-octo-potato.git
				synced 2025-10-25 11:09:18 +02:00 
			
		
		
		
	first dump I could find from my laptop
This commit is contained in:
		
							parent
							
								
									8d949a52b0
								
							
						
					
					
						commit
						034419b9a5
					
				
					 5 changed files with 310 additions and 0 deletions
				
			
		
							
								
								
									
										136
									
								
								discographymaker.py
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										136
									
								
								discographymaker.py
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,136 @@ | |||
| SPOTIFY_KEY = "" | ||||
| SPOTIFY_SECRET = "" | ||||
| SPOTIFY_USER_ID = "" | ||||
| 
 | ||||
| VERBOSE = True | ||||
| 
 | ||||
| import spotipy | ||||
| from spotipy.oauth2 import SpotifyOAuth | ||||
| 
 | ||||
| artists = [] | ||||
| albums = [] | ||||
| 
 | ||||
| def verboseprint(message: str) -> None: | ||||
|     if VERBOSE: | ||||
|         print(message) | ||||
| 
 | ||||
| def remove_duplicates(input_list: list) -> list: | ||||
|     return list(set(input_list)) | ||||
| 
 | ||||
| def spotifyauth() -> spotipy.Spotify: | ||||
|     return spotipy.Spotify(auth_manager=SpotifyOAuth(client_id=SPOTIFY_KEY, | ||||
|                                         client_secret=SPOTIFY_SECRET, | ||||
|                                         redirect_uri="http://localhost:6969", | ||||
|                                         scope="playlist-modify-public playlist-modify-private")) | ||||
| 
 | ||||
| def getDiscographyArtist(sp: spotipy.Spotify, first = False): | ||||
|     while True: | ||||
|         if first: | ||||
|             user_artist_input = input("Input your first Artist (name or spotify ID). Enter other's when prompted next:\n") | ||||
|         else: | ||||
|             print("======================") | ||||
|             user_artist_input = input("Input your next Artist (name or Spotify ID). Leave empty if all have been inputed\n") | ||||
|             if user_artist_input == "": return | ||||
|          | ||||
|         print("Looking up Artist...") | ||||
|         try: | ||||
|             if len(user_artist_input) == 22: | ||||
|                 if input("Did you Enter an ID? [ENTER for Yes, No for treating your Input as a name]: ") == "": | ||||
|                     return user_artist_input | ||||
|             search_results = sp.search(q=user_artist_input, type='artist', limit=1) | ||||
|             if search_results['artists']['items'][0]['name'] != user_artist_input: | ||||
|                 correct_input = input(" The Artist doesn't exist on Spotify. Did you mean \"" + search_results['artists']['items'][0]['name'] + "\" [ENTER for Yes, No for retry]: ") | ||||
|                 if correct_input == "": | ||||
|                     return search_results['artists']['items'][0]['uri'].replace("spotify:artist:", "") | ||||
|                 else: | ||||
|                     print("All good, try again!") | ||||
|                     continue | ||||
|             return search_results['artists']['items'][0]['uri'].replace("spotify:artist:", "")  | ||||
|         except TimeoutError: | ||||
|             print("\nNetwork unreachable. Please Try again...\n") | ||||
| 
 | ||||
| def ArtistAlbumGarbageHandler(apiresponse: list): | ||||
|     this_artist_album_part = [] | ||||
|     for i in apiresponse['items']: | ||||
|         this_artist_album_part.append((i['name'], i['id'], i['release_date'], i['artists'][0]['name'])) | ||||
|     verboseprint("Found " + str(len(this_artist_album_part)) + " Albums for " + apiresponse['items'][0]['artists'][0]['name']) | ||||
|     return this_artist_album_part | ||||
| 
 | ||||
| 
 | ||||
| def getArtistAlbum(sp: spotipy.Spotify, artists: list[str]) -> list[(str, str, str, str)]: | ||||
|     albums = [] | ||||
|     for artist in artists: | ||||
|         try: | ||||
|             this_artist_albums = [] | ||||
|             this_artist_album_part_garbage = sp.artist_albums(artist_id=artist, album_type="album,single,compilation", limit=50) | ||||
|             this_artist_albums = ArtistAlbumGarbageHandler(this_artist_album_part_garbage) | ||||
|             if this_artist_album_part_garbage['total'] > 50: | ||||
|                 print("There currently is a bug in the Spotify API that prevents fetching anything after the first 50 Albums. Given that your artist " + this_artist_album_part_garbage['items'][0]['artists'][0]['name'] + " has more than 50 Albums, you'll need to manually add the missing ones.") | ||||
|                 if input("Alternatively, you can end the script here since albums will be out of order [(E/e) to end] ") in ["E", "e", "end", "End"]: | ||||
|                     exit() | ||||
| 
 | ||||
|             albums.append(this_artist_albums) | ||||
|                  | ||||
|         except TimeoutError: | ||||
|             print("\nNetwork unreachable. THIS IS NOT RECOVERABLE. Please restart the process") | ||||
|             exit() | ||||
|     return albums | ||||
| 
 | ||||
| def insertion_sort(data_list): | ||||
|     for i in range(1, len(data_list)): | ||||
|         current_album = data_list[i] | ||||
|         current_date = current_album[2]  # Using index 2 for the release date | ||||
| 
 | ||||
|         j = i - 1 | ||||
|         while j >= 0 and data_list[j][2] > current_date: | ||||
|             data_list[j + 1] = data_list[j] | ||||
|             j -= 1 | ||||
|         data_list[j + 1] = current_album | ||||
|     return data_list | ||||
| 
 | ||||
| def createPlaylist(sp: spotipy.Spotify, songs: list[(str, str, str, str)], artist: str = None): | ||||
|     if artist == None: | ||||
|         artist = input("Primary Artist: ") | ||||
|     playlist = sp.user_playlist_create(SPOTIFY_USER_ID, artist + " Chronological Discography", description="Full Discography of " + artist + "and Solo Releases - no inst., no OSTs") | ||||
|     print('New Playlist created') | ||||
|     print("Name: " + playlist['name']) | ||||
|     print("ID: " + playlist['id']) | ||||
|     print("Description:", playlist['description']) | ||||
|     print("FAILED TO SET DESCRIPTION (Spotify API Bug)\nThe playlist was created anyways") if playlist['description'] == None else None | ||||
|     while len(songs) > 100: | ||||
|         sp.playlist_add_items(playlist['id'], songs[:100]) | ||||
|         songs = songs[100:] | ||||
|     sp.playlist_add_items(playlist['id'], songs) | ||||
| 
 | ||||
|     return playlist | ||||
| 
 | ||||
| def get_song_uris(album_id): | ||||
|     album_tracks = sp.album_tracks(album_id) | ||||
|     song_uris = [track['uri'] for track in album_tracks['items']] | ||||
|     return song_uris | ||||
| 
 | ||||
| verboseprint("Authenticating...") | ||||
| sp = spotifyauth() | ||||
| verboseprint("Authenticated!") | ||||
| 
 | ||||
| artist = getDiscographyArtist(sp, True) | ||||
| while artist != None: | ||||
|     artists.append(artist) | ||||
|     artist = getDiscographyArtist(sp) | ||||
| 
 | ||||
| def sort_key(item): | ||||
|     return item[2] | ||||
| 
 | ||||
| verboseprint("Fetching Albums...") | ||||
| albums_unsorted = [item for sublist in getArtistAlbum(sp, remove_duplicates(artists)) for item in sublist] | ||||
| albums = insertion_sort(albums_unsorted) | ||||
| verboseprint("Found " + str(len(albums))+ " Albums!") | ||||
| 
 | ||||
| all_song_uris = [] | ||||
| for album_id in albums: | ||||
|     album_song_uris = get_song_uris(album_id[1]) | ||||
|     all_song_uris.extend(album_song_uris) | ||||
| 
 | ||||
| playlist = createPlaylist(sp, all_song_uris, albums[0][3] if len(artists) == 1 else None) | ||||
| 
 | ||||
| print("Playlist created! Check your Spotify!") | ||||
							
								
								
									
										54
									
								
								lastfm-scrobble-fetch.py
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										54
									
								
								lastfm-scrobble-fetch.py
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,54 @@ | |||
| import requests | ||||
| from datetime import datetime | ||||
| import json | ||||
| import urllib.parse | ||||
| import time | ||||
| 
 | ||||
| starttime = time.time() | ||||
| 
 | ||||
| API_KEY = "" | ||||
| USERNAME = "" | ||||
| 
 | ||||
| # Get the total number of scrobbles for the user | ||||
| url = f"http://ws.audioscrobbler.com/2.0/?method=user.getinfo&user={USERNAME}&api_key={API_KEY}&format=json" | ||||
| response = requests.get(url) | ||||
| data = response.json() | ||||
| total_scrobbles = int(data['user']['playcount']) | ||||
| 
 | ||||
| # Calculate the number of pages required for pagination | ||||
| page_count = (total_scrobbles + 200 - 1) // 200 | ||||
| 
 | ||||
| # Fetch all scrobbles by paginating through the API responses | ||||
| all_scrobbles = [] | ||||
| for page in range(1, page_count + 1): | ||||
|     url = f"http://ws.audioscrobbler.com/2.0/?method=user.getrecenttracks&user={USERNAME}&api_key={API_KEY}&format=json&page={page}" | ||||
|     response = requests.get(url) | ||||
|     data = response.json() | ||||
|     tracks = data['recenttracks']['track'] | ||||
|      | ||||
|     for track in tracks: | ||||
|         artist = urllib.parse.quote(track['artist']['#text']) | ||||
|         song = urllib.parse.quote(track['name']) | ||||
|          | ||||
|         track_url = f"http://ws.audioscrobbler.com/2.0/?method=track.getInfo&api_key={API_KEY}&artist={artist}&track={song}&format=json" | ||||
|         #print(track_url) | ||||
|         track_response = requests.get(track_url) | ||||
|         track_data = track_response.json() | ||||
|         duration = int(track_data['track']['duration']) | ||||
|         track['duration'] = duration | ||||
|         all_scrobbles.append(track) | ||||
| 
 | ||||
| # Save the song list to a JSON file | ||||
| output_file = "song_list.json" | ||||
| with open(output_file, "w") as file: | ||||
|     json.dump(all_scrobbles, file) | ||||
| 
 | ||||
| total_duration = sum(track['duration'] for track in all_scrobbles) | ||||
| 
 | ||||
| print(total_duration) | ||||
| # Convert the total listening time to a human-readable format | ||||
| total_time = datetime.utcfromtimestamp(total_duration).strftime('%H:%M:%S') | ||||
| 
 | ||||
| print(f"Overall Listening Time: {total_time}") | ||||
| 
 | ||||
| print(f"Took: {time.time() - starttime}") | ||||
							
								
								
									
										79
									
								
								likedsongsync.py
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										79
									
								
								likedsongsync.py
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,79 @@ | |||
| LASTFM_KEY = "" | ||||
| LASTFM_SECRET = "" | ||||
| SPOTIFY_KEY = "" | ||||
| SPOTIFY_SECRET = "" | ||||
| 
 | ||||
| VERBOSE = True | ||||
| 
 | ||||
| import pylast, os, spotipy | ||||
| from spotipy.oauth2 import SpotifyOAuth | ||||
| 
 | ||||
| def verboseprint(message): | ||||
|     if VERBOSE: | ||||
|         print(message) | ||||
| 
 | ||||
| #last.fm auth | ||||
| def lastfmauth(): | ||||
|     SESSION_KEY_FILE = os.path.join(os.path.expanduser("~"), ".session_key") | ||||
|     network = pylast.LastFMNetwork(LASTFM_KEY, LASTFM_SECRET) | ||||
|     if not os.path.exists(SESSION_KEY_FILE): | ||||
|         skg = pylast.SessionKeyGenerator(network) | ||||
|         url = skg.get_web_auth_url() | ||||
| 
 | ||||
|         print(f"Please authorize this script to access your account: {url}\n") | ||||
|         import time | ||||
|         import webbrowser | ||||
| 
 | ||||
|         webbrowser.open(url) | ||||
| 
 | ||||
|         while True: | ||||
|             try: | ||||
|                 session_key = skg.get_web_auth_session_key(url) | ||||
|                 with open(SESSION_KEY_FILE, "w") as f: | ||||
|                     f.write(session_key) | ||||
|                 break | ||||
|             except pylast.WSError: | ||||
|                 time.sleep(1) | ||||
|     else: | ||||
|         session_key = open(SESSION_KEY_FILE).read() | ||||
| 
 | ||||
|     network.session_key = session_key | ||||
|     return network | ||||
| 
 | ||||
| #spotify | ||||
| def spotifyauth(): | ||||
|     return spotipy.Spotify(auth_manager=SpotifyOAuth(client_id=SPOTIFY_KEY, | ||||
|                                         client_secret=SPOTIFY_SECRET, | ||||
|                                         redirect_uri="http://localhost:42010", | ||||
|                                         scope="user-library-read")) | ||||
| def show_tracks(results): | ||||
|     tracknr = results['offset'] | ||||
|     for item in results['items']: | ||||
|         track = item['track'] | ||||
|         tracknr+=1 | ||||
|         verboseprint("%-10s %13s" % (f"ETA:{round((((int(results['total'])-tracknr)*0.25)/60))}min", f"[{tracknr}/{int(results['total'])}]") + "%32.32s %s" % (track['artists'][0]['name'], track['name'])) | ||||
|         #TODO: Fix this abomination | ||||
|         try: | ||||
|             track = network.get_track(track['artists'][0]['name'], track['name']) | ||||
|             track.love() | ||||
|         except pylast.NetworkError: | ||||
|             try: | ||||
|                 sleep(1) | ||||
|                 track = network.get_track(track['artists'][0]['name'], track['name']) | ||||
|                 track.love() | ||||
|             except pylast.NetworkError: | ||||
|                 verboseprint("Network error. Skipping..." + "%32.32s %s" % (track['artists'][0]['name'], track['name'])) | ||||
| 
 | ||||
| 
 | ||||
| verboseprint("Authenticating Spotify...") | ||||
| sp = spotifyauth() | ||||
| verboseprint("Done\nAuthenticating Last.fm") | ||||
| network = lastfmauth() | ||||
| verboseprint("Done!\nStarting...") | ||||
| 
 | ||||
| results = sp.current_user_saved_tracks() | ||||
| show_tracks(results) | ||||
| 
 | ||||
| while results['next']: | ||||
|     results = sp.next(results) | ||||
|     show_tracks(results) | ||||
							
								
								
									
										38
									
								
								linesum.py
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										38
									
								
								linesum.py
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,38 @@ | |||
| def convert_time_to_seconds(time_str): | ||||
|     # Split the time string into hours, minutes, and seconds | ||||
|     time_parts = time_str.split(':') | ||||
|     print(time_parts) | ||||
|     # Convert each part to an integer | ||||
|     minutes = int(time_parts[0]) | ||||
|     seconds = int(time_parts[1]) | ||||
|      | ||||
|     # Calculate the total time in seconds | ||||
|     total_seconds = minutes * 60 + seconds | ||||
|      | ||||
|     return total_seconds | ||||
| 
 | ||||
| 
 | ||||
| input_file = 'data.txt' | ||||
| total_product = 0 | ||||
| 
 | ||||
| with open(input_file, 'r') as file: | ||||
|     for line in file: | ||||
|         line_parts = line.strip().split(':::') | ||||
|         print(line_parts) | ||||
|          | ||||
|         # Extract the relevant information | ||||
|         avg_track_length = line_parts[6] | ||||
|         play_count = int(line_parts[3]) | ||||
|          | ||||
|         if avg_track_length == 'NaN:NaN': | ||||
|             # Use 3 minutes and 30 seconds (3:30) as the default track length | ||||
|             track_length_seconds = convert_time_to_seconds('0:03:30') | ||||
|         else: | ||||
|             # Convert average track length to seconds | ||||
|             track_length_seconds = convert_time_to_seconds(avg_track_length) | ||||
|          | ||||
|         # Calculate the product and add it to the total | ||||
|         product = track_length_seconds * play_count | ||||
|         total_product += product | ||||
| 
 | ||||
| print(f"Sum of (Average Track Length * Play Count): {total_product}") | ||||
							
								
								
									
										3
									
								
								trackduration-sum.py
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										3
									
								
								trackduration-sum.py
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,3 @@ | |||
| 
 | ||||
| 
 | ||||
| total_duration = sum(track['duration'] for track in all_scrobbles)  | ||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue