Spaces:
Sleeping
Sleeping
File size: 6,466 Bytes
3c15f87 6f318d3 50dc6d8 7a80241 1c9e038 7a80241 6f318d3 50dc6d8 7a80241 1c9e038 7a80241 1c9e038 7a80241 1c9e038 50dc6d8 1c9e038 4693fee 50dc6d8 4693fee 1c9e038 7a80241 1c9e038 7a80241 6f318d3 13f2ee3 7a80241 50dc6d8 7a80241 50dc6d8 7a80241 50dc6d8 7a80241 50dc6d8 7a80241 1c9e038 7a80241 1c9e038 50dc6d8 7a80241 50dc6d8 7a80241 50dc6d8 7a80241 50dc6d8 7a80241 50dc6d8 7a80241 50dc6d8 7a80241 1c9e038 7a80241 50dc6d8 7a80241 50dc6d8 7a80241 50dc6d8 7a80241 50dc6d8 7a80241 50dc6d8 7a80241 50dc6d8 7a80241 50dc6d8 7a80241 50dc6d8 7a80241 50dc6d8 3c15f87 6f318d3 50dc6d8 3c15f87 50dc6d8 6f318d3 3c15f87 7a80241 3c15f87 7a80241 50dc6d8 3c15f87 50dc6d8 3c15f87 7558062 |
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 |
import gradio as gr
import requests
from pydub import AudioSegment
import shazamio
import os
import time
import tempfile
from pathlib import Path
import sys
import asyncio
import base64 # Hinzugefügt, um base64 zu importieren
# Ersetzen Sie dies durch Ihre tatsächliche Client-ID und Client-Secret
client_id = os.environ.get('SOUNDCLOUD_CLIENT_ID')
client_secret = os.environ.get('SOUNDCLOUD_CLIENT_SECRET')
token = os.environ.get('TOKEN')
def get_soundcloud_access_token(client_id, client_secret):
try:
auth_string = f'{client_id}:{client_secret}'
auth_headers = {
'Authorization': 'Basic ' + base64.b64encode(auth_string.encode()).decode()
}
data = {
'grant_type': 'client_credentials'
}
response = requests.post('https://api.soundcloud.com/oauth2/token', headers=auth_headers, data=data)
response.raise_for_status() # Verwenden Sie raise_for_status, um Fehler zu behandeln
token_data = response.json()
return token_data['access_token']
except requests.RequestException as e:
return f"Fehler beim Abrufen des Zugriffstokens: {str(e)}"
def download_audio(streaming_url, output_path, headers):
try:
response = requests.get(streaming_url, headers=headers, stream=True)
response.raise_for_status() # Verwenden Sie raise_for_status, um Fehler zu behandeln
with open(output_path, 'wb') as f:
for chunk in response.iter_content(chunk_size=8192):
f.write(chunk)
except requests.RequestException as e:
raise Exception(f"Fehler beim Herunterladen des Audios: {str(e)}")
async def identify_track(shazam, audio_chunk, temp_dir):
try:
output_directory = "/tmp"
temp_file = os.path.join(temp_dir, 'temp_chunk.wav')
audio_chunk.export(output_directory, format='wav')
result = await shazam.recognize_file(temp_file)
if result and 'track' in result:
track_data = result['track']
return {
'title': track_data['title'],
'subtitle': track_data['subtitle']
}
return None
except Exception as e:
return f"Fehler bei der Identifizierung des Tracks: {str(e)}"
async def process_dj_set(track_url, progress=gr.Progress()):
with tempfile.TemporaryDirectory() as temp_dir: # Use a temporary directory
output_path = os.path.join(temp_dir, 'track.wav')
tracklist_path = os.path.join(temp_dir, 'tracklist.txt')
status_messages = []
# Überprüfen Sie die Umgebungsvariablen
if not client_id or not client_secret or not token:
return "", "", "Umgebungsvariablen sind nicht gesetzt."
# Zugriffstoken abrufen
access_token = get_soundcloud_access_token(client_id, client_secret)
if isinstance(access_token, str) and access_token.startswith("Fehler"):
return "", "", access_token
headers = {
'Authorization': f'Bearer {access_token}'
}
# Track-URL auflösen
try:
resolve_response = requests.get(f'https://api.soundcloud.com/resolve.json?url={track_url}', headers=headers)
resolve_response.raise_for_status() # Verwenden Sie raise_for_status, um Fehler zu behandeln
track_data = resolve_response.json()
streaming_url = track_data['stream_url']
status_messages.append("Track-URL erfolgreich aufgelöst.")
except requests.RequestException as e:
return "", "", f"Fehler beim Auflösen der Track-URL: {str(e)}"
# Audio herunterladen
try:
download_audio(streaming_url, output_path, headers)
status_messages.append("Audio erfolgreich heruntergeladen.")
except Exception as e:
return "", "", f"Fehler beim Herunterladen des Audios: {str(e)}"
# Audio laden
try:
audio = AudioSegment.from_wav(output_path)
status_messages.append("Audio erfolgreich geladen.")
except Exception as e:
return "", "", f"Fehler beim Laden des Audios: {str(e)}"
# Audio in Chunks aufteilen
chunk_duration = 30000 # 30 Sekunden
overlap = 10000 # 10 Sekunden
chunks = []
start = 0
while start + chunk_duration < len(audio):
end = start + chunk_duration
chunk = audio[start:end]
chunks.append((start, chunk))
start += chunk_duration - overlap
# Shazam initialisieren
shazam = shazamio.Shazam()
# Tracks identifizieren
tracklist = []
for start_time, chunk in chunks:
progress(0.1)
track_info = await identify_track(shazam, chunk, temp_dir)
if isinstance(track_info, dict):
timestamp = time.strftime("%M:%S", time.gmtime(start_time / 1000))
tracklist.append(f"{timestamp} - {track_info['title']} von {track_info['subtitle']}")
elif isinstance(track_info, str):
status_messages.append(track_info)
# Tracklist-Ausgabe vorbereiten
tracklist_output = "\n".join(tracklist)
with open(tracklist_path, 'w') as f:
f.write(tracklist_output)
# Temporäres Verzeichnis bereinigen
import shutil
shutil.rmtree(temp_dir)
# Statusnachricht vorbereiten
status_message = "\n".join(status_messages)
if not tracklist:
status_message += "\nKeine Tracks identifiziert."
return tracklist_output, tracklist_path, status_message
css = """
#col-container {
margin: 0 auto;
max-width: 640px;
}
"""
with gr.Blocks(css=css) as demo:
with gr.Column(elem_id="col-container"):
gr.Markdown("# SoundCloud DJ Set Track Identifier")
status_text = gr.Markdown(elem_id="status_text")
with gr.Row():
track_url = gr.Text(
label="SoundCloud DJ Set URL",
show_label=False,
max_lines=1,
placeholder="Geben Sie die SoundCloud DJ-Set-URL ein",
container=False,
)
run_button = gr.Button("Verarbeiten", scale=0, variant="primary")
result = gr.Textbox(label="Trackliste", show_label=False)
with gr.Accordion("Trackliste herunterladen", open=False):
download_button = gr.File(label="Herunterladen")
gr.Examples(examples=["https://soundcloud.com/your-track-url"], inputs=[track_url])
run_button.click(process_dj_set, inputs=track_url, outputs=[result, download_button, status_text])
if __name__ == "__main__":
demo.launch(share=False) |