amélioration du code encore (et fonction debug pour aider au debug)
authorDenise sur Lya <sekhmet@lya>
Fri, 19 Jun 2020 15:26:40 +0000 (17:26 +0200)
committerDenise sur Lya <sekhmet@lya>
Fri, 19 Jun 2020 15:26:40 +0000 (17:26 +0200)
app.py
configuration.py
gestion_erreurs.py
trace_courbe.py

diff --git a/app.py b/app.py
index 49a47a34746ab50d8013a29a4cf03a2ccbcc9283..d6f8507022a861e653ba1e151920fae9a2550af5 100644 (file)
--- a/app.py
+++ b/app.py
@@ -77,7 +77,7 @@ def courbe_image(ext):
                 "nomenfant": nomenfant})
         else:
             reponse = flask.jsonify({ "result":result, 
-                "messages": liste_err[1]+liste_err[0], 
+                "messages": liste_err[2]+liste_err[1]+liste_err[0], 
                 "image": "",
                 "export_txt": texte,
                 "nomenfant": nomenfant})
index 72e47a98955427d3705c573708fc1f8fae02359e..07cbf0e8ceee2d5277b107357e97983895ff7b11 100644 (file)
@@ -40,10 +40,9 @@ CONFIG["jours_dans_semaine"] = 7
 
 ## Maxi et mini de "sécurité"
 # jours maxi et mini
-CONFIG["jours_maxi_courbe"] = 5.5*CONFIG["jours_dans_annee"]
+CONFIG["jours_maxi_courbe"] = round(5.5*CONFIG["jours_dans_annee"])
 CONFIG["jours_mini_courbe"] = 10
-CONFIG["jours_defaut_donneesvides"]= 6*CONFIG["jours_dans_mois"] # si données vides, 6 mois
-jours_defaut_donneesvides = 6*CONFIG["jours_dans_mois"]
+CONFIG["jours_defaut_donneesvides"]= round(6*CONFIG["jours_dans_mois"]) # si données vides, 6 mois
 # poids max (protection)
 poids_maxi = 80
 # taille max du nom
index b47b61890e00211904b36f6c0c2848bf9729e0b4..4c9d602f7ffb1613ffb0f421e63596a756cf35f2 100644 (file)
@@ -8,24 +8,24 @@ niveau_debug = True
 
 
 def initialise_erreurs():
-    """ retourne deux listes vides, erreurs fatales (0) et warnings(1):"""
-    return ([],[])
+    """ retourne deux trois vides, erreurs fatales (0), warnings(1), debug:"""
+    return ([],[],[])
 
 
 def erreur(message,listeerreurs):
     """ en cas d'erreur où on ne peut pas continuer
     message est une chaîne"""
     print("** Erreur fatale : "+message)
-    listeerreurs[0].append(message)
+    listeerreurs[0].append("** Erreur : "+message)
   
     
 def warning(message,listeerreurs):
     """ En cas d'avertissement mais on peut quand même continuer """
     print("** Warning : "+message)
-    listeerreurs[1].append(message)
+    listeerreurs[1].append("Alerte : "+message)
     
 def debug(message,liste_erreurs):
     if niveau_debug:
         print("##Debug : "+message)
-        liste_erreurs[1].append("# Debug : "+message)
+        liste_erreurs[2].append("# Debug : "+message)
               
index ae48c41729c2931cd67f536f1460fd960bc95810..8fecd5670c0b5c77eaea915219e99a45b244ec89 100644 (file)
@@ -7,6 +7,7 @@ from gestion_unites import *
 import matplotlib.pyplot as plt
 
 def cree_figure(conf,l_jours,l_poids,liste_err):
+    debug("debut de cree_figure",liste_err)
     try:
         liste_data_labels_p,liste_data_labels_z = renvoie_liste_labels(conf,liste_data_choisie_p,liste_data_choisie_z,liste_err)
     except:
@@ -21,9 +22,11 @@ def cree_figure(conf,l_jours,l_poids,liste_err):
             jour_maxi = CONFIG["jours_defaut_donneesvides"] # si pas de données, arbitrairement on met ça
     else:
         jour_maxi = conf["maxi"]+1
-    
+        
+
     # On s'assure que c'est bien compris dans les bornes
     jour_maxi = max(CONFIG["jours_mini_courbe"],min(jour_maxi,CONFIG["jours_maxi_courbe"]))
+    debug("cree_figure : gestion du jour max ok : "+str(jour_maxi),liste_err)    
     
     if conf["unite"] == "":
         conf["unite"] = choix_unite(jour_maxi)
@@ -32,10 +35,10 @@ def cree_figure(conf,l_jours,l_poids,liste_err):
     # Attention, comme les jours commencent à partir de 0, faut enlever 1 pour avoir la borne...
     age_maxi = convertitunite(jour_maxi-1,conf["unite"],liste_err)
     
+    debug("cree_figure : conversion des unités ok",liste_err)        
 
     titre = "Courbe de poids OMS"
     
-    
     if conf["typecourbe"] == "P":
         # percentiles
         liste_data_labels = liste_data_labels_p
@@ -60,12 +63,11 @@ def cree_figure(conf,l_jours,l_poids,liste_err):
             fichier_oms = f_poids_z_mixte
             titre += " (moyenne et écarts-types)"
     else:
-        warning("Type de courbe invalide"+conf["typecourbe"],liste_err)
-
-#    warning("cree_figure : ça va jusque là ",liste_err)
-#    warning("bli"+str(conf),liste_err)
+        erreur("Type de courbe invalide"+conf["typecourbe"],liste_err)
+        return ""
    
-        
+    debug("cree_figure : géré le type de courbe ok",liste_err)         
+    
     # Si y'a un nom on met "courbe de machin"
     if conf["nom"] !="":
         titre += " de " +conf["nom"]
@@ -78,9 +80,16 @@ def cree_figure(conf,l_jours,l_poids,liste_err):
         t = lire_fichier_csv(fichier_oms)
     except:
         liste_err[0].append("Impossible d'ouvrir le fichier "+fichier_oms)
-    coljour = convertit_tableau(extraire_colonne(t,0,jour_maxi),conf["unite"],liste_err)
+        return ""
     
-
+    debug("cree_figure : on va convertir données OMS à la bonne unité",liste_err)
+    try:   
+        coljour = convertit_tableau(extraire_colonne(t,0,jour_maxi),conf["unite"],liste_err)
+    except:
+        erreur("Problème à la conversion du tableau OMS. jour_maxi = "+str(jour_maxi)+" unite = "+unite,liste_err)
+        return ""
+    
+    debug("cree_figure : prête à créer la figure",liste_err)   
     #### La figure
     fig = plt.figure(num=None, figsize=(conf["largeur"], conf["hauteur"]), dpi=100, facecolor=conf["couleurs"]["fond"])
     plt.rcParams['axes.facecolor'] = conf["couleurs"]["fond"]
@@ -95,7 +104,7 @@ def cree_figure(conf,l_jours,l_poids,liste_err):
         plt.plot(coljour,extraire_colonne(t,i,jour_maxi),label=label,color=couleur)
         #warning("colonne"+str(i)+str(label)+str(couleur),liste_err)
 
-
+    debug("cree_figure : tracé des courbes OMS ok",liste_err) 
     
     # On extrait la valeur min et la valeur max des poids
     (colonne_min,_,_) = liste_data_labels[-1]
@@ -113,9 +122,10 @@ def cree_figure(conf,l_jours,l_poids,liste_err):
     poids_max = poids_max * 1.05
     
     #warning("Jusque là ça marche",liste_err)
+    debug("cree_figure : prête à tracer la courbe de l'enfant",liste_err)
     
     if l_jours != []:
-        plt.plot(l_jours_conv,l_poids,label=conf["nom"],color=conf["couleur_cadretxt"],marker='o')
+        plt.plot(l_jours_conv,l_poids,label=conf["nom"],color=conf["couleurs"]["cadretxt"],marker='o')
     
     plt.xlabel("Âge en "+conf["unite"],color=conf["couleurs"]["cadretxt"])
     plt.ylabel("Poids en kg",color=conf["couleurs"]["cadretxt"])