import pandas as pd import json import matplotlib.pyplot as plt import streamlit as st import streamlit.components.v1 as stc import plotly.express as px import seaborn as sns from streamlit_option_menu import option_menu sns.set() logo = "https://www.ville-creteil.fr/img/Une-logo-pole-emploi.jpg" logo2 = "" st.set_page_config(page_icon = logo2, page_title ="Bonsoir !", layout = "wide") df = pd.read_csv("df_clean2.csv") departement_geo = json.load(open("departements.geojson", "r")) liste_dep = sorted(df.NomDept.unique().tolist()) liste_famille = df.famille.unique().tolist() liste_metier = list(df.metier.unique()) dico_map = {} for feature in departement_geo["features"]: feature['id']=feature['properties']['code'] dico_map[feature['properties']['nom']] = feature['id'] def heatmap(dep): departement = df[df.NomDept == dep] dep_tail = departement.groupby(["metier"]).agg({"Nbr_demande":"sum"}).sort_values(by="Nbr_demande", ascending = True).head(10) labels_tail = dep_tail.index.values.tolist() dep_head = departement.groupby(["metier"]).agg({"Nbr_demande":"sum"}).sort_values(by="Nbr_demande", ascending = True).tail(10) labels_head = dep_head.index.values.tolist() sns.set() dep_head.reset_index(inplace=True) dep_head = dep_head.sort_values("Nbr_demande", ascending = False) dep_head.columns = ["metier", "nbr_demande"] dep_tail.reset_index(inplace=True) dep_tail = dep_tail.sort_values("Nbr_demande", ascending = False) dep_tail.columns = ["metier", "nbr_demande"] fig1= plt.figure() sns.barplot(y= "metier", x= "nbr_demande", data = dep_head, orient="h", palette ="Reds_r") plt.xlabel("") plt.title("Les métier les plus demandés", fontsize= 18) plt.ylabel("") st.pyplot(fig1) fig2= plt.figure() sns.barplot(y= "metier", x= "nbr_demande", data = dep_tail, orient="h", palette ="Blues") plt.xlabel("") plt.title("Les métier les moins demandés", fontsize= 18) plt.ylabel("") plt.xlim(0,50) st.pyplot(fig2) def demande_metier(metier): df_metier = df[df.metier == metier] choro = df_metier.groupby(by=["NomDept"]).agg({"Nbr_demande":"sum"}) choro = choro.reset_index() choro['id']=choro['NomDept'].apply(lambda x: dico_map[x]) fig = px.choropleth_mapbox(choro, width = 900, height =100, locations="id", geojson = departement_geo, color = "Nbr_demande", hover_name = "NomDept", mapbox_style = "open-street-map", center = {"lat":46.80, "lon":3.02}, zoom = 5, opacity = 0.5, title = metier) fig.update_geos(fitbounds = "locations", visible = False) fig.update_layout(height=800, title_font_size = 25) st.plotly_chart(fig) def departement_page(): dep = st.selectbox("Choisir un département",liste_dep) heatmap(dep) def metier_page(): famille = st.selectbox("Famille de métier",liste_famille) liste_metier = df[df.famille == famille]["metier"].unique().tolist() metier = st.selectbox("Choisir un métier", liste_metier) demande_metier(metier) def contact_message(): st.header(":mailbox: Let's Get In Touch !") name, message = st.columns((1,2)) with name: contact_form = """
""" st.markdown(contact_form, unsafe_allow_html=True) with message : contact_form2 = """
""" st.markdown(contact_form2, unsafe_allow_html=True) with open("style.txt") as f: st.markdown(f"", unsafe_allow_html=True) def main(): st.title("Tendances de l'emploi en 2021") with st.sidebar: st.image(logo, width = 300) st.markdown("#") st.markdown("####") choice = option_menu( menu_title = "Analyses", options = ["Par département", "Par métier", "Envoie Moi Un Message"], icons=["house","hammer","envelope"], menu_icon="search" ) if choice == "Par département": departement_page() elif choice == "Par métier": metier_page() elif choice == "Envoie Moi Un Message": contact_message() st.sidebar.markdown("####") st.sidebar.markdown("####") st.sidebar.subheader(":notebook_with_decorative_cover: Par Maxime Le Tutour :relieved: ") st.sidebar.write(" :blue_book: [**LinkedIn**](https://www.linkedin.com/in/maxime-le-tutour-95994795/)", unsafe_allow_html =True) if __name__ == '__main__': main()