diff --git a/compte_test.csv b/compte_test.csv new file mode 100644 index 0000000..81a8736 --- /dev/null +++ b/compte_test.csv @@ -0,0 +1,5 @@ +nom montant +pipo 23 +hiphop 40 +chic 0 +Couette 500 diff --git a/pralo.py b/pralo.py index d8e7e4f..907a830 100644 --- a/pralo.py +++ b/pralo.py @@ -17,39 +17,28 @@ # ------------------------------ # Classes # ------------------------------ -class Pralo(): - """Pour faire ses comptes quand on part avec ses copains""" - def __init__(self, ): - super(Pralo, self).__init__() - - def open_file(self, file): - """Récupere les informations depuis un fichier CSV""" - pass - - def best_repart(self, e = 0): - """Calcul qui doit qui à qui en minimisant les échanges avec e la marge d'erreur""" - pass - - def print_bilan(self): - """Affiche le rendu des échanges""" - pass - # ------------------------------ # Fonctions # ------------------------------ +def extrait_from_file(file): + """Extrait les informations à partir d'un fichier""" + pass def echange(l): """Algo recursif pour gérer les échanges""" l.sort(key = lambda s: s[1]) m = l[0] M = l[-1] + + res = ['doneur','receveur',0] # Si celui qui doit le plus doit moins que le crédit que celui qui a le plus grand crédit # Il va donc tout lui donner if abs(m[1]) <= abs(M[1]): M2 = M[1] + m[1] - print("{em} donne {em_n} à {eM} donc {em} devient {eM2}".format(em = m[0], em_n = abs(m[1]), eM = M[0] , eM2 = M2)) + # print("{em} donne {em_n} à {eM} donc {em} devient {eM2}".format(em = m[0], em_n = abs(m[1]), eM = M[0] , eM2 = M2)) + res = [m[0], M[0], abs(m[1])] # On enleve le minimum l.remove(m) # ON change la valeur du max @@ -58,7 +47,8 @@ def echange(l): # Sinon il donne juste de quoi compenser else: m2 = m[1] + M[1] - print("{em} donne {eM_n} à {eM} et devient {em2}".format(em = m[0] , em2 = m2 , eM = M[0], eM_n = M[1])) + # print("{em} donne {eM_n} à {eM} et devient {em2}".format(em = m[0] , em2 = m2 , eM = M[0], eM_n = M[1])) + res = [m[0], M[0], abs(M[1])] # On eleve le max l.remove(M) # On change la valeur du min @@ -66,7 +56,9 @@ def echange(l): if (len(l) > 1): #print(l) - echange(l) + return [res] + echange(l) + else: + return [res] def normalise(compte): @@ -77,6 +69,15 @@ def normalise(compte): compte_normalise[i][1] = compte[i][1] - moyenne return compte_normalise +def affiche_final(donRec): + """Affiche qui donne quoi à qui à partir de la liste""" + for g in donRec: + print("{don} donne {montant} à {rec}".format(don = g[0], rec = g[1], montant = g[2])) + +def elimine_seuil(liste, seuil): + """Elimine les éléments de la liste qui sont sous le seuil """ + pass + # ------------------------------ # Bloc principal @@ -87,9 +88,10 @@ if __name__ == '__main__': # État des comptes compte = [['bob', 123] , ['pipo', 145] , ['hiphop', 43] , ['dede', 89] , ['chic', 0]] compte_normalise = normalise(compte) - print(compte_normalise) + # print(compte_normalise) - echange(compte_normalise) + final = echange(compte_normalise) + affiche_final(final) # ------------------------------ # Fin du programme # ------------------------------