mirror of
				https://github.com/JonasunderscoreJones/turbo-octo-potato.git
				synced 2025-10-25 19:19:19 +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