Spaces:
Sleeping
Sleeping
Create app.py
Browse files
app.py
ADDED
@@ -0,0 +1,146 @@
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
1 |
+
import streamlit as st
|
2 |
+
import pronotepy
|
3 |
+
from pronotepy.ent import *
|
4 |
+
|
5 |
+
# Configuration initiale
|
6 |
+
st.set_page_config(page_title="Contrôle Continu", page_icon="📚")
|
7 |
+
|
8 |
+
# Barème des points par niveau de maîtrise
|
9 |
+
bareme_points = {
|
10 |
+
"Très bonne maîtrise": 50,
|
11 |
+
"Maîtrise satisfaisante": 40,
|
12 |
+
"Maîtrise fragile": 25,
|
13 |
+
"Maîtrise insuffisante": 10
|
14 |
+
}
|
15 |
+
|
16 |
+
# Fonctions
|
17 |
+
def niveaux_maitrise_inverses():
|
18 |
+
return {v: k for k, v in bareme_points.items()}
|
19 |
+
|
20 |
+
def moyenne_a_maitrise(moyenne):
|
21 |
+
niveaux_inverses = niveaux_maitrise_inverses()
|
22 |
+
niveaux = sorted(niveaux_inverses.keys())
|
23 |
+
for i in range(len(niveaux) - 1):
|
24 |
+
if moyenne >= niveaux[i] and moyenne < niveaux[i + 1]:
|
25 |
+
return niveaux_inverses[niveaux[i + 1]]
|
26 |
+
return niveaux_inverses[niveaux[-1]]
|
27 |
+
|
28 |
+
# Fonction pour arrondir au niveau de maîtrise supérieur
|
29 |
+
def arrondir_maitrise(moyenne):
|
30 |
+
niveaux_inverses = niveaux_maitrise_inverses()
|
31 |
+
niveaux = sorted(niveaux_inverses.keys())
|
32 |
+
for i in range(len(niveaux) - 1):
|
33 |
+
if moyenne > niveaux[i] and moyenne <= niveaux[i + 1]: # Utilise ">" et "<=" pour arrondir au supérieur
|
34 |
+
return niveaux_inverses[niveaux[i + 1]]
|
35 |
+
return niveaux_inverses[niveaux[-1]]
|
36 |
+
|
37 |
+
# Gestion de session pour maintenir l'état
|
38 |
+
if 'client' not in st.session_state:
|
39 |
+
st.session_state.client = None
|
40 |
+
|
41 |
+
def connecter():
|
42 |
+
selected_cas = cas if college_selectionne == 'Autre' else colleges[college_selectionne][1]
|
43 |
+
st.session_state.client = pronotepy.Client(url if college_selectionne == 'Autre' else colleges[college_selectionne][0], username, password, getattr(pronotepy.ent, selected_cas, None))
|
44 |
+
if not st.session_state.client.logged_in:
|
45 |
+
st.error("Erreur de connexion. Veuillez vérifier vos identifiants.")
|
46 |
+
else:
|
47 |
+
st.success("Connecté avec succès !")
|
48 |
+
|
49 |
+
def deconnecter():
|
50 |
+
st.session_state.client = None
|
51 |
+
st.rerun()
|
52 |
+
|
53 |
+
# Interface utilisateur
|
54 |
+
st.title('Contrôle Continu 📚')
|
55 |
+
|
56 |
+
# Définition des options du menu déroulant
|
57 |
+
colleges = {
|
58 |
+
'Autre': ('', ''),
|
59 |
+
'Louise Weiss': ('https://0952236p.index-education.net/pronote/eleve.html', 'val_doise'),
|
60 |
+
}
|
61 |
+
|
62 |
+
cas_options = [
|
63 |
+
'Aucune', 'ac_orleans_tours', 'ac_poitiers', 'ac_reunion', 'ac_reims',
|
64 |
+
'ac_rennes', 'atrium_sud', 'cas_agora06', 'cas_arsene76_edu', 'cas_cybercolleges42_edu',
|
65 |
+
'cas_kosmos', 'cas_seinesaintdenis_edu', 'eclat_bfc', 'ecollege_haute_garonne_edu',
|
66 |
+
'ent_94', 'ent_auvergnerhonealpe', 'ent_creuse', 'ent_creuse_educonnect', 'ent_elyco',
|
67 |
+
'ent_essonne', 'ent_hdf', 'ent_mayotte', 'ent_somme', 'ent_var', 'ent77',
|
68 |
+
'ent_ecollege78', 'extranet_colleges_somme', 'ile_de_france', 'laclasse_educonnect',
|
69 |
+
'laclasse_lyon', 'l_normandie', 'lyceeconnecte_aquitaine', 'lyceeconnecte_edu',
|
70 |
+
'monbureaunumerique', 'neoconnect_guadeloupe', 'occitanie_montpellier',
|
71 |
+
'occitanie_montpellier_educonnect', 'occitanie_toulouse_edu', 'paris_classe_numerique',
|
72 |
+
'val_de_marne', 'val_doise'
|
73 |
+
]
|
74 |
+
|
75 |
+
if st.session_state.client is None:
|
76 |
+
college_selectionne = st.selectbox("🏫 Choisissez votre collège :", list(colleges.keys()))
|
77 |
+
cas = st.selectbox("📍 Si votre collège n'est pas listé, choisissez votre cas :", cas_options) if college_selectionne == 'Autre' else colleges[college_selectionne][1]
|
78 |
+
url = st.text_input('🧷 URL Pronote', value=colleges[college_selectionne][0]) if college_selectionne == 'Autre' else colleges[college_selectionne][0]
|
79 |
+
username = st.text_input('1️⃣ Nom d\'utilisateur', '')
|
80 |
+
password = st.text_input('2️⃣ Mot de passe', '', type='password')
|
81 |
+
|
82 |
+
st.button('🟢 Se connecter', on_click=connecter)
|
83 |
+
else:
|
84 |
+
if st.button('🔴 Se déconnecter'):
|
85 |
+
deconnecter()
|
86 |
+
|
87 |
+
# Sélection de la période
|
88 |
+
periode = st.selectbox("🏫 Voir mes points par domaines des autres Périodes :", ["Contrôle Continu (Toute l'année)", "Trimestre 1", "Trimestre 2", "Trimestre 3"], index=0)
|
89 |
+
periode_selectionnee = 0 if periode == "Contrôle Continu (Toute l'année)" else int(periode.replace('Trimestre ', ''))
|
90 |
+
|
91 |
+
# Initialisation des dictionnaires pour stocker les points par domaine
|
92 |
+
total_points_par_domaine = {}
|
93 |
+
nombre_acquisitions_par_domaine = {}
|
94 |
+
total_arrondi = 0
|
95 |
+
|
96 |
+
if periode_selectionnee in [1, 2, 3]:
|
97 |
+
current_period = [st.session_state.client.periods[periode_selectionnee - 1]]
|
98 |
+
else:
|
99 |
+
current_period = st.session_state.client.periods
|
100 |
+
|
101 |
+
for period in current_period:
|
102 |
+
evaluations = period.evaluations
|
103 |
+
for evaluation in evaluations:
|
104 |
+
for acquisition in evaluation.acquisitions:
|
105 |
+
domaines = acquisition.pillar_prefix.split(", ")
|
106 |
+
niveau_maitrise = acquisition.level
|
107 |
+
coefficient = acquisition.coefficient # Récupère le coefficient de l'acquisition
|
108 |
+
points = bareme_points.get(niveau_maitrise, 0) * coefficient # Multiplie les points par le coefficient
|
109 |
+
|
110 |
+
for domaine in domaines:
|
111 |
+
if domaine != "":
|
112 |
+
if domaine not in total_points_par_domaine:
|
113 |
+
total_points_par_domaine[domaine] = points
|
114 |
+
nombre_acquisitions_par_domaine[domaine] = 1
|
115 |
+
else:
|
116 |
+
total_points_par_domaine[domaine] += points
|
117 |
+
nombre_acquisitions_par_domaine[domaine] += 1
|
118 |
+
|
119 |
+
with st.expander("🔍 Détails des points par domaine"):
|
120 |
+
domaine_named = {
|
121 |
+
"D1.1": "1️⃣ D1.1 - Langue française à l'oral et à l'écrit",
|
122 |
+
"D1.2": "2️⃣ D1.2 - Langues étrangères et régionales",
|
123 |
+
"D1.3": "3️⃣ D1.3 - Langages mathématiques, scientifiques et informatiquese",
|
124 |
+
"D1.4": "4️⃣ D1.4 - Langage des arts et du corps",
|
125 |
+
"D2": "5️⃣ D2 - Les méthodes et outils pour apprendre",
|
126 |
+
"D3": "6️⃣ D3 - La formation de la personne et du citoyen",
|
127 |
+
"D4": "7️⃣ D4 - Les systèmes naturels et les systèmes techniques",
|
128 |
+
"D5": "8️⃣ D5 - Les représentations du monde et l'activité humaine"
|
129 |
+
}
|
130 |
+
# Iterate through sorted domain points to display them with friendly names
|
131 |
+
for domaine, points in sorted(total_points_par_domaine.items(), key=lambda item: item[0]):
|
132 |
+
moyenne = points / nombre_acquisitions_par_domaine[domaine]
|
133 |
+
niveau_maitrise = arrondir_maitrise(moyenne) # Utilise la fonction d'arrondi au niveau de maîtrise supérieur
|
134 |
+
points_maitrise = bareme_points[niveau_maitrise]
|
135 |
+
total_arrondi += points_maitrise
|
136 |
+
st.metric(domaine_named.get(domaine, domaine), f"{points_maitrise} points / 50 points")
|
137 |
+
|
138 |
+
# Calcul et affichage de la moyenne totale des points
|
139 |
+
total_points = sum(total_points_par_domaine.values())
|
140 |
+
nombre_total_acquisitions = sum(nombre_acquisitions_par_domaine.values())
|
141 |
+
moyenne_totale = total_points / nombre_total_acquisitions if nombre_total_acquisitions != 0 else 0
|
142 |
+
niveau_maitrise_totale = moyenne_a_maitrise(moyenne_totale)
|
143 |
+
|
144 |
+
# Verifier si c'est un trimestre ou toute l'année
|
145 |
+
if periode == "Contrôle Continu (Toute l'année)":
|
146 |
+
st.metric("📁 Points du controle continu (*environ*)", f"{total_arrondi} / 400 points")
|