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", []) | |
| # Ensure that 'point_geo' is extracted correctly as a dictionary with 'lat' and 'lon' | |
| cleaned_data = [] | |
| for record in records: | |
| item = record["fields"] | |
| point_geo = item.get("point_geo", {}) | |
| if isinstance(point_geo, dict): | |
| lat = point_geo.get("lat") | |
| lon = point_geo.get("lon") | |
| if lat and lon: | |
| item['latitude'] = lat | |
| item['longitude'] = lon | |
| cleaned_data.append(item) | |
| return cleaned_data, data.get("nhits", 0) | |
| else: | |
| return [], 0 | |
| def display_map(data): | |
| m = folium.Map(location=[44.837789, -0.57918], zoom_start=12) | |
| for item in data: | |
| lat = item.get('latitude') | |
| lon = item.get('longitude') | |
| if lat and lon: | |
| folium.Marker( | |
| [lat, lon], | |
| icon=folium.Icon(color="green", icon="leaf"), | |
| popup=item.get('Nom', 'Sans nom'), | |
| ).add_to(m) | |
| folium_static(m) | |
| 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) | |
| def main(): | |
| st.sidebar.title("Navigation") | |
| app_mode = st.sidebar.radio("Choisissez l'onglet", ["Organisations engagées", "Localisation des Entreprises"]) | |
| if app_mode == "Organisations engagées": | |
| display_organisations_engagees() | |
| elif app_mode == "Localisation des Entreprises": | |
| data, _ = get_data() | |
| display_map(data) | |
| if __name__ == "__main__": | |
| main() | |