Merge branch 'seuil' into development

This commit is contained in:
Lafrite 2013-08-14 10:45:10 +02:00
commit bccea81276

View File

@ -55,11 +55,12 @@ def extrait_from_file(file_name):
file.close() file.close()
def echange(l): def echange(l, seuil = 0):
""" """
Algo recursif pour gérer les échanges Algo recursif pour gérer les échanges
:param l: liste des valeurs associées aux débits des comptes :param l: liste des valeurs associées aux débits des comptes
:param seuil: seuil à partir duquel on ne doit plus rien.
:return: liste des valeurs associées aux débits des comptes après le remboursement :return: liste des valeurs associées aux débits des comptes après le remboursement
""" """
l.sort(key = lambda s: s[1]) l.sort(key = lambda s: s[1])
@ -88,10 +89,13 @@ def echange(l):
l.remove(M) l.remove(M)
# On change la valeur du min # On change la valeur du min
l[0] = [m[0], m2] l[0] = [m[0], m2]
# Gestion du Seuil
l = [i for i in l if abs(i[1]) >= seuil]
if (len(l) > 1): if (len(l) > 1):
#print(l) #print(l)
return [res] + echange(l) return [res] + echange(l,seuil=seuil)
else: else:
return [res] return [res]
@ -109,7 +113,7 @@ def forfait(compte):
print("Le nombre de jour passé {njour}".format(njour = nbr_jour)) print("Le nombre de jour passé {njour}".format(njour = nbr_jour))
cout_jour = cout_total / nbr_jour cout_jour = cout_total / nbr_jour
print("Cout au jour: {cout}".format(cout = cout_jour)) print("Cout au jour: {cout}".format(cout = round(cout_jour,2)))
print("\n") print("\n")
@ -136,12 +140,7 @@ def affiche_final(donRec):
:param donRec: liste avec qui doit quoi à qui [[qui, àqui, quoi]...] :param donRec: liste avec qui doit quoi à qui [[qui, àqui, quoi]...]
""" """
for g in donRec: for g in donRec:
print("{don} donne {montant} à {rec}".format(don = g[0], rec = g[1], montant = g[2])) print("{don} donne {montant} à {rec}".format(don = g[0], rec = g[1], montant = round(g[2],2)))
def elimine_seuil(liste, seuil):
"""Elimine les éléments de la liste qui sont sous le seuil """
pass
# ------------------------------ # ------------------------------
@ -153,6 +152,7 @@ if __name__ == '__main__':
parser = optparse.OptionParser() parser = optparse.OptionParser()
# options proposée # options proposée
parser.add_option("-f","--file",action="store", type = "string", dest="file_name", help="Analyse les comptes à partir du fichier donné en argument") parser.add_option("-f","--file",action="store", type = "string", dest="file_name", help="Analyse les comptes à partir du fichier donné en argument")
parser.add_option("-e","--seuil",action="store", type = "int", dest="seuil",default=0, help="Seuil à partir duquel on concidère qu'il n'est plus nécessaire de payer.")
# Digestion # Digestion
(options, args) = parser.parse_args() (options, args) = parser.parse_args()
@ -160,7 +160,7 @@ if __name__ == '__main__':
compte = extrait_from_file(options.file_name)[1:] compte = extrait_from_file(options.file_name)[1:]
# compte_normalise = normalise(compte) # compte_normalise = normalise(compte)
compte_normalise = forfait(compte) compte_normalise = forfait(compte)
final = echange(compte_normalise) final = echange(compte_normalise, options.seuil)
affiche_final(final) affiche_final(final)
# ------------------------------ # ------------------------------