Compare commits

..

No commits in common. "d7ceff8bb81ca60ef80a5b3eebd8796d7ac76dc9" and "56787e631a65104ceda1e93fbd8aa704d4d2d16c" have entirely different histories.

7 changed files with 84 additions and 106 deletions

View File

@ -1,58 +0,0 @@
# Comptes Pralo
Programme de coin de table pour faire les comptes entre amis.
## Mode d'emploi: compte unique
On écrit ce que chacun à payé au long du séjour et on renseigne le temps de séjour pour chaque personne dans un fichier .csv .
**example/compte.csv**
nom,montant, parts
pipo, 20 + 3, 3
hiphop, 40, 4
chic, 0, 4
Couette,50, 1
On lance le programme avec le fichier en argument
python -m pralo -f example/compte.csv
Cout total: 113
Nombre de parts 12
Cout de la part: 9.42
chic donne 37.67 à Couette
pipo donne 2.92 à Couette
pipo donne 2.33 à hiphop
## Mode d'emploi: multicompte
Le principe est le meme, on écrit les dépenses dans autant que fichiers .csv qu'il y a de comptes. On place ces fichiers dans une meme repertoire et on fait tourner le programme dessus:
python -m pralo -f example/multicompte/
Compte: transport.csv
Cout total: 40
Nombre de parts 5
Cout de la part: 8.0
Compte: logement.csv
Cout total: 30
Nombre de parts 3
Cout de la part: 10.0
Compte: courses.csv
Cout total: 113
Nombre de parts 12
Cout de la part: 9.42
Chic donne 37.67 à Couette
chic donne 16.0 à Couette
Pipo donne 15.25 à Couette
Plop donne 3.67 à Couette
Plop donne 2.33 à Hiphop

31
README.rst Normal file
View File

@ -0,0 +1,31 @@
Comptes Pralo
=============
Outils codé rapidemenet pour faire les comptes en fin de séjour.
Utilisation
-----------
On écrit ce que chacun à payé au long du séjour et on renseigne le temps de séjour pour chaque personne dans un fichier .csv .
compte_test.csv::
nom,montant, jours
pipo, 20 + 3, 3
hiphop, 40, 4
chic, 0, 4
Couette,50, 1
Puis on fait tourner le programme sur le fichier::
> pralo.py -f compte_test.csv
Cout total de Pralo: 113
Le nombre de jour passé 12
Cout au jour: 9.42
chic donne 37.67 à Couette
pipo donne 2.92 à Couette
pipo donne 2.33 à hiphop

View File

@ -1,5 +0,0 @@
nom,montant,parts
pipo, 20 + 3, 3
hiphop, 40, 4
chic, 0, 4
Couette,50, 1
1 nom montant parts
2 pipo 20 + 3 3
3 hiphop 40 4
4 chic 0 4
5 Couette 50 1

View File

@ -1,5 +0,0 @@
nom,montant, parts
Pipo, 20 + 3, 3
Hiphop, 40, 4
Chic, 0, 4
Couette,50, 1
1 nom montant parts
2 Pipo 20 + 3 3
3 Hiphop 40 4
4 Chic 0 4
5 Couette 50 1

View File

@ -1,4 +0,0 @@
nom,montant, parts
Pipo, 0, 1
Chic, 10, 1
Couette,20, 1
1 nom montant parts
2 Pipo 0 1
3 Chic 10 1
4 Couette 20 1

View File

@ -1,4 +0,0 @@
nom,montant, parts
chic, 0, 2
Couette,30, 1
Plop, 10, 2
1 nom montant parts
2 chic 0 2
3 Couette 30 1
4 Plop 10 2

View File

@ -19,12 +19,19 @@ from pathlib import Path
from account import Account from account import Account
# ------------------------------
# Classes
# ------------------------------
# ------------------------------
# Fonctions
# ------------------------------
def extrait_from_file(file_name): def extrait_from_file(file_name):
""" """
Extrait les informations à partir d'un fichier Extrait les informations à partir d'un fichier
:param file_name: nom du fichier avec les comptes :param file_name: nom du fichier avec les comptes
:return: liste [[nom,montant,parts],...] :return: liste [[nom,montant,jours],...]
""" """
file = open(file_name, "r") file = open(file_name, "r")
try: try:
@ -41,35 +48,37 @@ def extrait_from_file(file_name):
compte["nom"] = c[i] compte["nom"] = c[i]
if "montant" in h.lower(): if "montant" in h.lower():
compte["montant"] = eval(c[i]) compte["montant"] = eval(c[i])
if "part" in h.lower(): if "jour" in h.lower():
compte["parts"] = int(c[i]) compte["jours"] = int(c[i])
comptes += [compte] comptes += [compte]
return comptes return comptes
finally: finally:
file.close() file.close()
def forfait(compte, output = print): def forfait(compte, output = print):
""" """
Gère le nombre de parts et affiche quelques stats Gère le nombre de jours resté à Pralo et affiche quelques stats
:param compte: comptes de ce que chacun a payé [[nom, montant,parts],...] :param compte: comptes de ce que chacun a payé [[nom, montant,jours],...]
:return: Comptes des crédits de chacun envers la communauté :return: Comptes des crédits de chacun envers la communauté
""" """
cout_total = sum([c["montant"] for c in compte]) cout_total = sum([c["montant"] for c in compte])
output("Cout total: {cout_tot}".format(cout_tot = cout_total)) output("Cout total de Pralo: {cout_tot}".format(cout_tot = cout_total))
nbr_jour = sum([c["parts"] for c in compte]) nbr_jour = sum([c["jours"] for c in compte])
output("Nombre de parts {njour}".format(njour = nbr_jour)) output("Le nombre de jour passé {njour}".format(njour = nbr_jour))
cout_jour = cout_total / nbr_jour cout_jour = cout_total / nbr_jour
output("Cout de la part: {cout}".format(cout = round(cout_jour,2))) output("Cout au jour: {cout}".format(cout = round(cout_jour,2)))
output("\n") output("\n")
new_compte = [] new_compte = []
for pers in compte: for pers in compte:
new_compte += [[pers["nom"], (pers["montant"] - pers["parts"] * cout_jour)]] new_compte += [[pers["nom"], (pers["montant"] - pers["jours"] * cout_jour)]]
return new_compte return new_compte
@ -83,6 +92,7 @@ def normalise(compte):
return compte_normalise return compte_normalise
def affiche_final(donRec, output = print): def affiche_final(donRec, output = print):
""" """
Affiche qui donne quoi à qui à partir de la liste Affiche qui donne quoi à qui à partir de la liste
@ -105,39 +115,52 @@ def join_comptes(compte1, compte2):
joined = {k: c_dict1.get(k, 0) + c_dict2.get(k, 0) for k in set(c_dict1) | set(c_dict2)} joined = {k: c_dict1.get(k, 0) + c_dict2.get(k, 0) for k in set(c_dict1) | set(c_dict2)}
return [(k, v) for k,v in joined.items()] return [(k, v) for k,v in joined.items()]
# ------------------------------
# Bloc principal
# ------------------------------
if __name__ == '__main__': if __name__ == '__main__':
# Pour analyser les options qu'on lui demande # Pour analyser les options qu'on lui demande
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 ou des fichiers du repertoire") 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("-p","--path",action="store", type = "string", dest="pathname", help="Analyse les comptes à partir de tous les fichiers csv du repertoir (multicompte)") parser.add_option("-p","--path",action="store", type = "string", dest="pathname", help="Analyse les comptes à partir de tous les fichiers csv du repertoir (multicompte)")
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.") 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()
if options.file_name: if options.file_name:
path = Path(options.file_name) compte = extrait_from_file(options.file_name)
# compte_normalise = normalise(compte)
compte_normalise = forfait(compte)
#final = echange(compte_normalise, options.seuil)
account = Account(compte_normalise)
final = account.tribut(options.seuil)
affiche_final(final)
if options.pathname:
path = Path(options.pathname)
assert path.exists() assert path.exists()
if path.is_dir():
god = [] god = []
for f in path.glob('*.csv'): for f in path.glob('*.csv'):
print(f"Compte: {f.name}") print(f"Compte: {f.name}")
compte = extrait_from_file(f) compte = extrait_from_file(f)
compte_normalise = forfait(compte) compte_normalise = forfait(compte)
print(compte_normalise)
god = join_comptes(god, compte_normalise) god = join_comptes(god, compte_normalise)
account = Account(god)
else:
compte = extrait_from_file(options.file_name)
# compte_normalise = normalise(compte)
cred_dept = forfait(compte)
#final = echange(compte_normalise, options.seuil)
account = Account(cred_dept)
print("")
print(god)
account = Account(god)
final = account.tribut(options.seuil) final = account.tribut(options.seuil)
affiche_final(final) affiche_final(final)
# ------------------------------
# Fin du programme
# ------------------------------
# ----------------------------- # -----------------------------
# Reglages pour 'vim' # Reglages pour 'vim'
# vim:set autoindent expandtab tabstop=4 shiftwidth=4: # vim:set autoindent expandtab tabstop=4 shiftwidth=4: