PYTR / app.py
sudo-soldier's picture
Update app.py
6542b78 verified
raw
history blame
3.25 kB
import os
import gradio as gr
import yt_dlp
from pydub import AudioSegment
import re
import subprocess
import time
if not os.path.exists("downloads"):
os.makedirs("downloads")
def sanitize_filename(filename):
"""Sanitize filenames to avoid special characters."""
return re.sub(r'[^a-zA-Z0-9_-]', '_', filename)
def process_youtube_or_audio(url, uploaded_audio, start_time, end_time):
try:
filename = None
song_name = None
print(f"URL: {url}") # Debug: Check URL input
print(f"Uploaded audio: {uploaded_audio}") # Debug: Check if audio is uploaded
print(f"Start time: {start_time}, End time: {end_time}") # Debug: Check times
# Process YouTube URL
if url:
print("Processing YouTube URL...")
ydl_opts = {
'format': 'bestaudio/best',
'outtmpl': 'downloads/%(id)s.%(ext)s',
'cookiefile': 'cookies.txt'
}
with yt_dlp.YoutubeDL(ydl_opts) as ydl:
info = ydl.extract_info(url, download=True)
filename = os.path.join('downloads', f"{info['id']}.webm")
song_name = sanitize_filename(info['title'])
# Process uploaded audio file
elif uploaded_audio:
print("Processing uploaded audio...")
filename = uploaded_audio.name # Using the uploaded file's name
song_name = "uploaded_audio"
if not filename or not os.path.exists(filename):
print(f"Error: No valid file found at {filename}") # Debug
return None, None
# Load audio and trim it
audio = AudioSegment.from_file(filename)
start_time_ms = start_time * 1000
end_time_ms = end_time * 1000
start_time_ms = max(0, min(start_time_ms, len(audio)))
end_time_ms = max(start_time_ms, min(end_time_ms, len(audio)))
trimmed_audio = audio[start_time_ms:end_time_ms]
# Export trimmed audio
mp3_filename = f"downloads/{song_name}.mp3"
trimmed_audio.export(mp3_filename, format="mp3")
# Convert to m4r format for iPhone
m4a_filename = f"downloads/{song_name}.m4a"
try:
subprocess.run([
'ffmpeg', '-i', mp3_filename, '-vn', '-acodec', 'aac', '-b:a', '192k', m4a_filename
], stdout=subprocess.PIPE, stderr=subprocess.PIPE, timeout=30, check=True)
except subprocess.TimeoutExpired:
print("Error: ffmpeg took too long to process the file.")
return None, None
except subprocess.CalledProcessError as e:
print(f"ffmpeg error: {e}")
return None, None
# Ensure the file exists before renaming
if os.path.exists(m4a_filename):
m4r_filename = f"downloads/{song_name}.m4r"
os.rename(m4a_filename, m4r_filename)
print(f"Files saved: {mp3_filename}, {m4r_filename}") # Debug
return os.path.abspath(mp3_filename), os.path.abspath(m4r_filename)
else:
print("Error: M4A file not created.")
return None, None
except Exception as e:
print(f"Error: {e}") # Debug: Print the error
return None, None