chainenombre = ""
elif lettre != ' ':
# autre caractère : bizarre ?
- warning("convertit_jour_vers_python : caractère invalide : "+lettre,liste_err)
+ warning("problème à la conversion de "+chaine+". Caractère invalide : "+lettre,liste_err)
# à la fin s'il reste qqch on le garde dans les jours
if chainenombre != "":
agejours += int(chainenombre)
def convertit_date_vers_python(chaine,liste_err):
""" prend une chaine comme renvoyée par un champ de formulaire date
aaaa-mm-jj et en fait une date python
- renvoie "" si ne marche pas"""
- liste = chaine.split("-")
+ renvoie "" si ne marche pas.
+ Si jamais la date est au format avec des / ça devrait passer aussi."""
+ if "/" in chaine:
+ liste = chaine.split("/")
+ else:
+ liste = chaine.split("-")
if len(liste) != 3:
warning("La date : "+chaine+" est invalide !",liste_err)
return ""
if date == "":
return ""
else:
- return (str(date.year)+"-"+str(date.month)+"-"+str(date.day))
-
+ #return (str(date.year)+"-"+str(date.month)+"-"+str(date.day))
+ return str(date)
-def delta_date(date1,datenaissance):
+def delta_date(date1,datenaissance, liste_err):
""" renvoie le nombre de jours (entier) entre date1 et datenaissance format "datetime"
datenaissance est supposée antérieure. Erreur sinon."""
d = date1 - datenaissance
jours = d.days
if jours<0:
- warning("La différence entre les dates est négative... :/")
+ warning("Une des dates saisies ("+str(date1)+") est inférieure à la date de naissance (la donnée est donc ignorée)", liste_err)
return -1
return jours
+
################### On regroupe tout ce qui gère les données en une fonction
def web_vers_python(data,liste_err, court=False):
""" prend en argument le dictionnaire de requête et renvoie la config, et les
- tableaux de donnée
+ tableaux de données
court : si True est précisé, on ne met que le nom dans la config (enfant
additionnel)"""
sexe = data.get("sexe","")
if not (sexe in ["F","M","N"]):
- warning("Le sexe de l'enfant est invalide ! "+sexe,liste_err)
+ warning("Le sexe de l'enfant est invalide. "+sexe,liste_err)
sexe = "N"
configuration["sexe"] = sexe
configuration["non_sauve"]["calculextratemps_trace"] = gere_checkbox(data.get("calculextratemps_trace"))
+ ### Gestion des repères additionnels
+ configuration["liste_reperes"] = []
+ i=0
+ while "repere_texte_"+str(i) in data: # Tant qu'il y a des trucs définis
+ debug("Repère trouvé", liste_err)
+ age=data.get("repere_age_"+str(i), "")
+ trace=gere_checkbox(data.get("repere_trace_"+str(i), ""))
+ if age !="":
+ agec=convertit_jours_vers_python(age, liste_err)
+ texte = data.get("repere_texte_"+str(i), "") # Même si le texte est vide, osef
+ configuration["liste_reperes"].append({"typed": "age", "donnee": agec, "texte": texte, "trace": trace})
+ i+=1
+
return configuration
i = 0
# On va chercher si y'a des données à donnee_i
- while typedonnee+"_"+str(i) in data.keys():
- if data[typedonnee+"_"+str(i)] != "":
+ while "age_"+str(i) in data.keys():
+ if data.get(typedonnee+"_"+str(i), "") != "": # si la donne de ce type existe
donnee = convertit_donnee_vers_python(data[typedonnee+"_"+str(i)],typedonnee,liste_err)
age = data.get("age_"+str(i),"")
if age !="":
if naissance == "":
warning("La date de naissance n'a pas été précisée. Du coup on ne peut pas calculer l'âge de l'enfant le "+date,liste_err)
elif datep != "": # la date est valide et on a une date de naissance
- age = delta_date(datep,naissance)
- liste_donnees.append((age,donnee))
+ age = delta_date(datep,naissance, liste_err)
+ if age != -1: # -1 signifie une erreur donc on ne garde pas la donnée
+ liste_donnees.append((age,donnee))
i+=1
# Trier la liste
return (l_jours,l_donnee)
+# web vers python : enfants additionnels
+def gere_enfants_additionnels(data, files, liste_err):
+ """ data est le dictionnaire de requête.
+ files est le dictionnaire des fichiers (flask.request.files).
+ Renvoie les enfants additionnels sous forme de liste de dictionnaires :
+ {typed: (conf, lj, ldonnees)}
+ Dans conf y'a les infos qu'il faut pour tracer la courbe additionnelle voulue.
+ """
+
+ enfants_add = [] # Enfants additionnels
+ # Les enfants additionnels commencent à 2 (puis 3, 4, etc)
+ i=2
+ while "couleur_donnees_"+str(i) in data: # Tant qu'il y a des données de ce type
+ if 'fichier_donnees_'+str(i) in files: # Un enfant à ajouter
+ fichier = files["fichier_donnees_"+str(i)]
+ chaine = fichier.read() # On récupère la chaîne
+ if len(chaine)>=5: # Si elle a une longueur à peu près raisonnable
+ debug("Un fichier de données additionnel trouvé", liste_err)
+ formulaire_2 = fichier_json_vers_configdonnees(chaine, liste_err)
+ if formulaire_2 =={}:
+ warning("Le fichier de données additionnel est vide ou mal formaté", liste_err)
+ else:
+ debug("Form 2 : "+str(formulaire_2), liste_err)
+ # Récupérer sous forme python
+ conf2, ljours2, listes_donnees2 = web_vers_python(formulaire_2,liste_err, court=True)
+ debug("Form 2 données travaillées "+str(ljours2)+str(listes_donnees2), liste_err)
+ # Le symbole et la couleur
+ symb2 = gere_symbole(data.get("symbole_donnees_"+str(i)))
+ coul2 = rgb_vers_tuple(data.get("couleur_donnees_"+str(i),""),CONFIG["couleurs"]["cadretxt"],liste_err)
+ enfant2 = eclate_donnees_additionnelles(conf2, ljours2, listes_donnees2, symb2, coul2)
+ enfants_add.append(enfant2)
+ i+=1
+
+ return enfants_add
+
+
+
+
# python vers Json
#### export vers json
def donnees_vers_json(l_jours,l_poids,l_jourst,l_taille,config):
""" retourne le json à renvoyer"""
gros_dico = copy.deepcopy(config)
+ gros_dico["version"] = CONFIG["version"]
l_jours2 = [convertit_age_vers_texte(d) for d in l_jours]
l_jourst2 = [convertit_age_vers_texte(d) for d in l_jourst]
gros_dico["data_j"] = l_jours2
# gérer la date de naissance
if gros_dico.get("naissance","") != "":
gros_dico["naissance"] = convertit_date_vers_texte(gros_dico["naissance"])
+ # Calcul de toutes les dates de données
+ l_dates_poids = [convertit_date_vers_texte( config["naissance"] + datetime.timedelta(days=jours) ) for jours in l_jours]
+ l_dates_taille = [convertit_date_vers_texte( config["naissance"] + datetime.timedelta(days=jours) ) for jours in l_jourst]
+ gros_dico["data_dates_poids"]= l_dates_poids
+ gros_dico["data_dates_taille"] = l_dates_taille
+
+
# gérer l'age maxi
gros_dico["maxi"] = convertit_age_vers_texte(gros_dico["maxi"])
+ # Gérer les repères
+ for i in range(len(gros_dico["liste_reperes"])):
+ gros_dico["liste_reperes"][i]["donnee"] = convertit_age_vers_texte(gros_dico["liste_reperes"][i]["donnee"])
# gérer les couleurs
for clecouleur in DEFAUT["couleurs"]:
gros_dico["couleurs"][clecouleur] = tuple_vers_rgb(gros_dico["couleurs"][clecouleur])
return json.dumps(gros_dico, indent=2,ensure_ascii=False )
-def fusionne_donnees(listes_jours,listes_donnees):
+def fusionne_donnees(listes_jours,listes_donnees, listes_dates):
""" prend en argument deux dicos de listes. Chaque liste de jours est associée à une liste
de données (par la même clé de type de données). Il faut les fusionner pour avoir une liste de dictionnaires, de type
- ("age":truc, "donnee1":truc, "donnee2":truc, ...) triée par ordre de jours. Si jamais une des données est vide,
- le champ du dictionnaire n'est pas rempli"""
+ {"age":truc, "donnee1":truc, "donnee2":truc, ...} triée par ordre de jours. Si jamais une des données est vide,
+ le champ du dictionnaire n'est pas rempli
+ Le troisième paquet de listes (les dates) peut être vide ou bien simiaire : même clés."""
def fini(lj):
""" teste si les listes sont toutes vides """
# On extrait les données dans les deux listes (jours et données)
jour = listes_jours[typedonnee].pop(0)
donnee = listes_donnees[typedonnee].pop(0)
+
if liste_f == [] or jour != liste_f[-1]["age"]: # Si le jour est un "nouveau" jour
liste_f.append({"age":jour})
- # On met à jour l'élément
+ # On met à jour l'élément (ou on l'ajoute)
liste_f[-1][typedonnee] = donnee
+ # Si il y a une date associée, on la met !
+ if listes_dates[typedonnee] != []:
+ date = listes_dates[typedonnee].pop(0)
+ liste_f[-1]["date"] = convertit_date_vers_texte(date)
+
+
return liste_f
listes_jours = {}
listes_donnees = {}
+ listes_dates = {}
for typed in CONFIG["liste_typedonnees"]:
if typed == "poids": # pour la rétrocompatibilité
listes_jours[typed] = valform.get("data_j",[])
listes_donnees[typed] = valform.get("data_p",[])
+ listes_dates[typed] = valform.get("data_dates_"+typed,[])
else:
listes_jours[typed] = valform.get("data_jours_"+typed,[])
listes_donnees[typed] = valform.get("data_"+typed,[])
+ listes_dates[typed] = valform.get("data_dates_"+typed,[])
+
debug("Avant fusion : listes jours "+str(listes_jours),liste_err)
- liste_donnees = fusionne_donnees(listes_jours,listes_donnees)
+ liste_donnees = fusionne_donnees(listes_jours,listes_donnees, listes_dates)
debug("Fusion de listes ok. Liste moche : "+str(liste_donnees),liste_err)
for i in range(len(liste_donnees)):
for (cle,val) in liste_donnees[i].items():
""" conf est la config (on ne garde que le nom) pour un enfant additionnel,
ljours et ldonnees les dictionnaires de listes contenant les données.
symb est le symbole choisi pour cette courbe additionnelle (déjà vérifié)
- On fabrique un joli dictionnaire typed -> (conf lj, ldonnee) avec le nom de l'enfant,
+ On fabrique un joli dictionnaire typed -> (conf, lj, ldonnee) avec le nom de l'enfant,
et les données pour chaque typed"""
+ #print("test conf avant "+str(ldonnees)+str(ljours))
retour = {}
conf["symbole"] = symb # On ajoute le symbole additionnel
for typed in CONFIG["liste_typedonnees"]:
retour[typed] = (conf, ljours[typed], ldonnees[typed])
+ #print("test "+str(retour))
return retour
\ No newline at end of file