OpenData-Projet-RSE / organisations_engagees.py
LaurentTRIPIED's picture
Pytorch V0.25
b73754a
raw
history blame
1.72 kB
import streamlit as st
import pandas as pd
import requests
def get_data():
url = "https://opendata.bordeaux-metropole.fr/api/records/1.0/search/?dataset=met_etablissement_rse&q=&rows=100"
try:
response = requests.get(url)
response.raise_for_status() # Cela va déclencher une exception pour les réponses non-200
data = response.json()
records = data.get("records", [])
if records:
return [record.get("fields") for record in records]
else:
st.error("Aucun enregistrement trouvé dans les données de l'API.")
return []
except requests.RequestException as e:
st.error(f"Erreur lors de la récupération des données de l'API: {e}")
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")
data = get_data()
if data:
num_etablissements = len(data)
st.markdown(f"Nombre d'établissements : {num_etablissements}")
df = pd.DataFrame(data)
df = df[['nom_courant_denomination', 'commune', 'libelle_section_naf', 'tranche_effectif_entreprise', 'action_rse']].rename(columns={
'nom_courant_denomination': 'Nom',
'commune': 'Commune',
'libelle_section_naf': 'Section NAF',
'tranche_effectif_entreprise': 'Effectif',
'action_rse': 'Action RSE'
})
st.dataframe(df)
else:
st.error("Données OPEN DATA RSE Bordeaux non disponibles actuellement. Veuillez vous reconnecter ultérieurement.")
if __name__ == "__main__":
display_organisations_engagees()