import streamlit as st
import pandas as pd
import requests
import folium
from streamlit_folium import folium_static
# Fonction pour récupérer les données de l'API
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", [])
return [record["fields"] for record in records], data.get("nhits", 0)
else:
return [], 0
# Fonction pour l'onglet "Organisations engagées"
def display_organisations_engagees():
st.markdown("## OPEN DATA RSE")
st.markdown("### Découvrez les organisations engagées RSE de la métropole de Bordeaux")
data, _ = get_data()
if data:
df = pd.DataFrame(data)
df = df.rename(columns={
"nom_courant_denomination": "Nom",
"commune": "Commune",
"libelle_section_naf": "Section NAF",
"tranche_effectif_entreprise": "Effectif",
"action_rse": "Action RSE"
})
df = df[["Nom", "Commune", "Section NAF", "Effectif", "Action RSE"]]
st.dataframe(df, width=None, height=None)
# Nouvelle fonction pour l'onglet "GeoRSE Insights"
def display_geo_rse_insights():
data, _ = get_data()
if data:
m = folium.Map(location=[44.84474, -0.60711], zoom_start=11)
for item in data:
point_geo = item.get('point_geo', [])
if point_geo:
lat, lon = point_geo
lat, lon = float(lat), float(lon)
if lat and lon:
folium.Marker(
[lat, lon],
popup=f"{item.get('nom_courant_denomination', 'Sans nom')}
Action RSE: {item.get('action_rse', 'Non spécifié')}",
icon=folium.Icon(color="green", icon="leaf"),
).add_to(m)
folium_static(m)
# Main function orchestrating the app UI
def main():
st.sidebar.title("Navigation")
app_mode = st.sidebar.radio("Choisissez l'onglet", ["Organisations engagées", "GeoRSE Insights"])
if app_mode == "Organisations engagées":
display_organisations_engagees()
elif app_mode == "GeoRSE Insights":
display_geo_rse_insights()
if __name__ == "__main__":
main()