yt-summarizer / app.py
nabeelarain713's picture
Upload app.py
283ba3b verified
import streamlit as st
from dotenv import load_dotenv
load_dotenv() ##load all the nevironment variables
import os
import google.generativeai as genai
from youtube_transcript_api import YouTubeTranscriptApi
genai.configure(api_key="AIzaSyBjEeTXoxrkk3eFc_o_CAfHMIfgWglPrlU")
prompt="""You are Yotube video summarizer. You will be taking the transcript text
and summarizing the entire video and providing the important summary
within 200 words. Please provide the summary of the text given here: """
## getting the summary based on Prompt from Google Gemini Pro
def generate_gemini_content(transcript_text,prompt):
model=genai.GenerativeModel("gemini-pro")
response=model.generate_content(prompt+transcript_text)
return response.text
st.title("YouTube Video Summarizer")
youtube_link = st.text_input("Enter YouTube Video Link:")
if youtube_link:
try:
video_id = youtube_link.split("=")[1]
# print(video_id)
st.image(f"http://img.youtube.com/vi/{video_id}/0.jpg", use_container_width=True)
# Fetch subtitles
transcript_list = YouTubeTranscriptApi.list_transcripts(video_id)
data = ""
for transcript in transcript_list:
if transcript.is_translatable:
subtitles = transcript.translate('en').fetch()
data += " ".join([entry['text'] for entry in subtitles])
if data:
st.subheader("Extracted Subtitles")
st.write(data)
if st.button("Summarize"):
with st.spinner("Summarizing..."):
summary = generate_gemini_content(data, prompt)
st.subheader("Summary")
st.write(summary)
# transcript_text=YouTubeTranscriptApi.get_transcript(video_id)
# transcript = ""
# for i in transcript_text:
# transcript += " " + i["text"]
# return transcript
except Exception as e:
raise e
# if st.button("Summarize"):
# if transcript_text:
# summary=generate_gemini_content(transcript_text,prompt)
# st.markdown("## Summary:")
# st.write(summary)
# # App title
# st.title("YouTube Video Summarizer")
# # Input: YouTube video URL
# video_url = st.text_input("Enter YouTube Video URL:")
# if video_url:
# try:
# # Extract video ID from the URL
# if "youtube.com" in video_url:
# video_id = video_url.split("v=")[-1]
# elif "youtu.be" in video_url:
# video_id = video_url.split("/")[-1]
# else:
# st.error("Invalid YouTube URL!")
# video_id = None
# if video_id:
# # Fetch subtitles
# transcript_list = YouTubeTranscriptApi.list_transcripts(video_id)
# data = ""
# for transcript in transcript_list:
# if transcript.is_translatable:
# subtitles = transcript.translate('en').fetch()
# data += " ".join([entry['text'] for entry in subtitles])
# break
# # Display subtitles
# if data:
# st.subheader("Extracted Subtitles")
# st.write(data)
# # Summarize subtitles
# if st.button("Summarize"):
# with st.spinner("Summarizing..."):
# summary = generate_gemini_content(data, prompt)
# st.subheader("Summary")
# st.write(summary)
# else:
# st.warning("No subtitles found for this video.")
# except Exception as e:
# st.error(f"An error occurred: {e}")