Compare commits
No commits in common. "d7ceff8bb81ca60ef80a5b3eebd8796d7ac76dc9" and "56787e631a65104ceda1e93fbd8aa704d4d2d16c" have entirely different histories.
d7ceff8bb8
...
56787e631a
58
README.md
58
README.md
@ -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
31
README.rst
Normal 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
|
||||||
|
|
@ -1,5 +0,0 @@
|
|||||||
nom,montant,parts
|
|
||||||
pipo, 20 + 3, 3
|
|
||||||
hiphop, 40, 4
|
|
||||||
chic, 0, 4
|
|
||||||
Couette,50, 1
|
|
|
@ -1,5 +0,0 @@
|
|||||||
nom,montant, parts
|
|
||||||
Pipo, 20 + 3, 3
|
|
||||||
Hiphop, 40, 4
|
|
||||||
Chic, 0, 4
|
|
||||||
Couette,50, 1
|
|
|
@ -1,4 +0,0 @@
|
|||||||
nom,montant, parts
|
|
||||||
Pipo, 0, 1
|
|
||||||
Chic, 10, 1
|
|
||||||
Couette,20, 1
|
|
|
@ -1,4 +0,0 @@
|
|||||||
nom,montant, parts
|
|
||||||
chic, 0, 2
|
|
||||||
Couette,30, 1
|
|
||||||
Plop, 10, 2
|
|
|
65
pralo.py
65
pralo.py
@ -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:
|
||||||
|
Loading…
Reference in New Issue
Block a user