LaurentTRIPIED's picture
Pytorch V0.10
79104c9
raw
history blame
2.38 kB
import streamlit as st
import pandas as pd
import requests
import folium
from streamlit_folium import folium_static
def get_data():
url = "https://opendata.bordeaux-metropole.fr/api/records/1.0/search/?dataset=met_etablissement_rse&q=&rows=100"
response = requests.get(url)
if response.status_code == 200:
data = response.json()
records = data.get("records", [])
cleaned_data = []
for record in records:
fields = record.get("fields", {})
if fields: # Assurer que le champ n'est pas vide
cleaned_data.append(fields)
return cleaned_data
else:
return []
def display_organisations_engagees(data):
st.markdown("## OPEN DATA RSE")
st.markdown("### Découvrez les organisations engagées RSE de la métropole de Bordeaux")
# Compter le nombre d'établissements et afficher le nombre
num_etablissements = len(data)
st.markdown(f"Nombre d'établissements : {num_etablissements}")
if data:
df = pd.DataFrame(data)
df = df[['nom_courant_denomination', 'commune', 'libelle_section_naf', 'tranche_effectif_entreprise', 'action_rse']]
df.rename(columns={
'nom_courant_denomination': 'Nom',
'commune': 'Commune',
'libelle_section_naf': 'Section NAF',
'tranche_effectif_entreprise': 'Effectif',
'action_rse': 'Action RSE'
}, inplace=True)
st.dataframe(df)
else:
st.write("Aucune donnée disponible.")
def display_map(data):
m = folium.Map(location=[44.837789, -0.57918], zoom_start=12)
for item in data:
geoloc = item.get('geolocalisation')
if geoloc:
folium.Marker(
location=[geoloc[0], geoloc[1]],
icon=folium.Icon(color="green", icon="leaf"),
popup=item.get('nom_courant_denomination', 'Information non disponible'),
).add_to(m)
folium_static(m)
def main():
st.sidebar.title("Navigation")
app_mode = st.sidebar.radio("Choisissez l'onglet", ["Organisations engagées", "Localisation des Entreprises"])
data = get_data()
if app_mode == "Organisations engagées":
display_organisations_engagees(data)
elif app_mode == "Localisation des Entreprises":
display_map(data)
if __name__ == "__main__":
main()