File size: 1,607 Bytes
cbf58a5
 
 
 
 
 
 
a0bdeee
cbf58a5
a0bdeee
cbf58a5
 
 
 
a0bdeee
cbf58a5
 
a0bdeee
 
cbf58a5
a0bdeee
cbf58a5
a0bdeee
cbf58a5
 
 
 
 
a0bdeee
cbf58a5
 
 
 
 
a0bdeee
cbf58a5
 
 
 
 
 
 
 
a0bdeee
cbf58a5
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
import time
import gradio as gr
from selenium.webdriver.common.by import By
import undetected_chromedriver as uc

def get_captions_selenium(video_url):
    try:
        print("πŸš€ Launching Chrome...")
        options = uc.ChromeOptions()
        options.add_argument("--headless=new")  # Use 'new' headless mode for Chrome 109+
        options.add_argument("--no-sandbox")
        options.add_argument("--disable-dev-shm-usage")

        driver = uc.Chrome(options=options)
        print("🌍 Navigating to video...")
        driver.get(video_url)

        print("βŒ› Waiting for page to load...")
        time.sleep(5)

        print("πŸ“„ Scraping page source...")
        page_source = driver.page_source

        if "captionTracks" in page_source:
            start = page_source.find("captionTracks")
            end = page_source.find("]", start) + 1
            caption_json = page_source[start:end]
            driver.quit()
            return "βœ… Found potential captions info in page source (you may need to parse this JSON).\n\n" + caption_json
        else:
            driver.quit()
            return "⚠️ Captions info not found in source. May not be available or blocked."

    except Exception as e:
        print(f"❌ Exception occurred: {e}")
        return f"❌ Error: {str(e)}"

# Gradio interface
gr.Interface(
    fn=get_captions_selenium,
    inputs=[gr.Textbox(label="YouTube Video URL")],
    outputs="text",
    title="YouTube Captions Scraper (Selenium)",
    description="Uses Selenium with undetected-chromedriver to extract captions from a YouTube video."
).launch()