Spaces:
Runtime error
Runtime error
| 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", {}) | |
| # Assurez-vous que les champs nécessaires existent | |
| if all(key in fields for key in ['nom_courant_denomination', 'commune', 'libelle_section_naf', 'tranche_effectif_entreprise', 'action_rse']): | |
| 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") | |
| 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() | |