Spaces:
Sleeping
Sleeping
File size: 3,023 Bytes
3b47f92 68fec35 3b47f92 68fec35 9ffeec1 3b47f92 68fec35 3b47f92 |
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 |
import recomender
import streamlit as st
import requests
import pandas as pd
df_cbf_Q = pd.read_csv('df_cbf_Q.csv', low_memory = False)
list_of_all_movies = list(df_cbf_Q['original_title'])
################################################################
def get_movie_information(movie_title):
params={"apikey": "c176e26f", "t": movie_title, "plot": "full"}
response = requests.get("http://www.omdbapi.com/", params=params)
if response.status_code == 200:
data = response.json()
if data["Response"] == "False":
print(data["Error"])
else:
return data
else:
print("Error:", response.status_code)
#######################################################################
def show_image(index):
dict_movie =get_movie_information(list_of_movies[index])
st.header(dict_movie["Title"])
st.subheader(dict_movie["Year"])
if dict_movie["Poster"] != "N/A":
st.image(dict_movie["Poster"], use_column_width=False)
else:
st.write("Poster is not available!")
st.markdown(f"**IMDB Rating:** {dict_movie['imdbRating']} / 10")
st.markdown(f"**Director:** {dict_movie['Director']}")
st.markdown(f"**Actors:** {dict_movie['Actors']}")
st.markdown(f"**Writer:** {dict_movie['Writer']}")
st.markdown(f"**Genre:** {dict_movie['Genre']}")
st.markdown(f"**Year:** {dict_movie['Year']}")
st.markdown(f"**Country:** {dict_movie['Country']}")
st.markdown(f"**Language:** {dict_movie['Language']}")
st.write(f"**Plot:** {dict_movie['Plot']}")
#####################################################################################################
st.set_page_config(page_title="Movie Info", page_icon=":movie_camera:")
st.title("Movie Recommender Engine")
system_option = st.radio(" How would you like us to choose your next movie?"
,("Best Movies of all time","Trend Movies","Special for You:)", " People with similar tast like (CFR)"))
movies_watched = st.multiselect("What are your top three fovorite movies? (At least 3 movies)", list_of_all_movies)
###########################################################################################
suggest_button = st.button("Suggests me new movies to watch! ")
if suggest_button:
if len(movies_watched) < 3:
st.error(" You need to mention 3 movies!")
else:
if system_option == "Best Movies of all time":
list_of_movies = recomender.final_recommender_hot_picks_of_all_time(movies_watched)
elif system_option == "Trend Movies":
list_of_movies = recomender.final_recommender_hot_picks_now(movies_watched)
elif system_option == "Special for You:)":
list_of_movies = recomender.final_recommender_for_you(movies_watched)
else:
list_of_movies = recomender.recommender_svd(movies_watched)
for i,_ in enumerate(list_of_movies):
show_image(i)
|