Telegram Bot To Download Youtube Playlist Official
[Unit] Description=YouTube Playlist Telegram Bot After=network.target [Service] User=youruser WorkingDirectory=/home/youruser/youtube-playlist-bot ExecStart=/home/youruser/youtube-playlist-bot/venv/bin/python bot.py Restart=always
What it does: User sends a YouTube playlist URL → Bot processes the playlist → Downloads each video/audio → Sends files to Telegram chat.
for idx, video in enumerate(videos, 1): await context.bot.send_message(chat_id, f"⬇️ Downloading idx/len(videos): video['title']") try: if format_type == 'video': file_path = await loop.run_in_executor( executor, download_video, video['url'], user_dir ) else: file_path = await loop.run_in_executor( executor, download_audio, video['url'], user_dir ) # Step 3: Send file with open(file_path, 'rb') as f: if format_type == 'video': await context.bot.send_video(chat_id, f, caption=video['title']) else: await context.bot.send_audio(chat_id, f, title=video['title']) # Clean up os.remove(file_path) except Exception as e: await context.bot.send_message(chat_id, f"Failed for video['title']: str(e)") Telegram Bot To Download Youtube Playlist
async def start(update, context): await update.message.reply_text( "Send me a YouTube playlist URL.\n" "I'll download up to 15 videos (audio or video)." )
import os file_size_mb = os.path.getsize(file_path) / (1024 * 1024) if file_size_mb > 50: await context.bot.send_message( chat_id, f"⚠️ video['title'] is file_size_mb:.1fMB > 50MB, skipped." ) continue 5.1 User Queue to Avoid Overload user_tasks = {} async def process_playlist_safe(chat_id, url, format_type, context): if chat_id in user_tasks and not user_tasks[chat_id].done(): await context.bot.send_message(chat_id, "You already have a playlist processing. Please wait.") return video in enumerate(videos
with yt_dlp.YoutubeDL(ydl_opts) as ydl: ydl.download([video_url]) # return actual file path info = ydl.extract_info(video_url, download=False) filename = ydl.prepare_filename(info).replace('.webm', '.mp4') return filename
# Store URL in user_data context.user_data['playlist_url'] = url buttons = [[ InlineKeyboardButton("🎵 Audio (MP3)", callback_data="audio"), InlineKeyboardButton("🎬 Video (MP4)", callback_data="video") ]] await update.message.reply_text( "Choose format:", reply_markup=InlineKeyboardMarkup(buttons) ) def main(): app = Application.builder().token(BOT_TOKEN).build() app.add_handler(CommandHandler("start", start)) app.add_handler(MessageHandler(filters.TEXT & ~filters.COMMAND, handle_message)) app.run_polling() 1): await context.bot.send_message(chat_id
Add to main:
async def process_playlist(chat_id, url, format_type, context): # Step 1: Get playlist entries loop = asyncio.get_event_loop() try: videos = await loop.run_in_executor(executor, get_playlist_info, url) except Exception as e: await context.bot.send_message(chat_id, f"Failed to fetch playlist: e") return if not videos: await context.bot.send_message(chat_id, "No videos found or playlist empty.") return