Exercices corrigés Python (Série 10)
Exercice 1
Soit un fichier typé intitulé concours.txt qui comporte les enregistrements relatifs aux candidats d’un concours. Chaque enregistrement est composé de : NCIN, NOM, PRENOM, AGE, DECISION : (type contenant les identificateurs suivants : admis, refusé, ajourné), et séparé par point virgule (;).
Travail demandé :
- Définir la fonction saisir() qui permet de remplir les données relatives aux candidats dans le fichier concours.txt
- Définir la fonction admis() qui permet créer le fichier admis.txt comportant les données relatives aux candidat admis
- Afin de sélectionner en priorité les candidats admis et âgés moins de 30 ans, créer la fonction attente() qui produira à partir du fichier admis.txt, un nouveau fichier intitulé attente.txt comportant les données relatives aux candidats admis et âgés plus que 30 ans. Une ligne du fichier attente.txt comprend le NCIN, le NOM et PRENOM d’un candidat séparés par point virgule (;).
- Définir la fonction statistiques(dec) qui permet de retourner le pourcentage des candidats pour la décision dec (admis, refusé et ajourné). Exemple : Le pourcentage des candidats admis = (Nombre des candidats admis / Nombre des candidats) *100
- Définir la fonction supprimer() qui supprimera du fichier admis.txt les candidat âgés plus que 30
N.B : On suppose que les fichiers seront mis à la racine du lecteur C.
Solution :
def saisir(): new = "O" # O -> oui ; N -> non fichier = open("concours.txt", "a") decision = {"a": "admis(e)", "r": "refuse(e)", "aj": "ajourne(e)"} while new == "O": cin = input("Saisir le Numero CIN : ") nom = input("Saisir le Nom : ") prenom = input("Saisir le prenom : ") age = input("saisir l age ") dec = input("saisir la decision a(admis(e)) r(refuse(e)) aj(ajourne(e)): ") ligne = cin+";"+nom+";"+prenom+";"+age+";"+decision[dec]+"\n" fichier.write(ligne) new = input("Saisir un nouveau candidat, (O / N) ?") fichier.close() def admis(): fichier = open("concours.txt") dest = open("admis.txt", "a") for ligne in fichier: L = ligne.split(";") if L[4].strip() == "admis(e)": dest.write(ligne) fichier.close() dest.close() def attente(): fichier = open("admis.txt") dest = open("attente.txt", "a") for ligne in fichier: L = ligne.split(";") if int(L[3]) >= 30: enreg = L[0]+";"+L[1]+";"+L[2]+"\n" dest.write(enreg) fichier.close() dest.close() def statistiques(dec): fichier = open("concours.txt") L = fichier.readlines() fichier.close() L1 = [] # candidats admis L2 = [] # candidats refuses L3 = [] # candidats ajournes for ligne in L: L = ligne.split(";") if L[4].strip() == "admis(e)": L1.append(ligne) elif L[4].strip() == "refuse(e)": L2.append(ligne) else: L3.append(ligne) if dec == "admis": return (len(L1)/len(L))*100 elif dec == "refuse": return (len(L2)/len(L))*100 else: return (len(L3)/len(L))*100 def supprimer(): fichier = open("admis.txt") candidat = [] # contient les candidats restants for ligne in fichier: L = ligne.split(";") if int(L[3]) < 30: candidat.append(ligne) fichier.close() # reecrire la nouvelle liste fichier = open("admis.txt", "w") fichier.writelines(candidat) fichier.close()
Exercice 2
Après la réussite au baccalauréat, les meilleurs bacheliers sont orientés vers les classes préparatoires aux grandes écoles. En effet, la priorité est à celui qui a le score (nombre de points) le plus élevé. Ce score est appelé formule globale.
Les élèves admissibles seront classés par ordre décroissant selon la formule globale, Puis, une fois classés, ces bacheliers seront divisés en 4 groupes de la façon suivante :
Groupe | description | Nb d’étudiants | Répartition |
Principale | Liste principale | 30 | 40% (SMA) ; 30% (SMB) ; 20% (PC) ; 10% (SVT) |
Tranche 1 | Liste d’attente N°1 | 40 | 50% (SMA) ; 25% (SMB) ; 20% (PC) ; 5% (SVT) |
Tranche 2 | Liste d’attente N°2 | 60 | 40% (SMA) ; 30% (SMB) ; 20% (PC) ; 10% (SVT) |
Tranche 3 | Liste d’attente N°3 | 50 | 55% (SMA) ; 25% (SMB) ; 20% (PC) ; |
Dans le répertoire C:/bachelier, on dispose d’un fichier nommé ‘PSI.txt’ contenant la liste des bacheliers admissibles de la section Physique et sciences industrielles. Dans ce fichier, chaque bachelier est défini par :
- Num_insc : le numéro d’inscription
- NP : le nom et prénom
- FILIERE : le nom de la filière (SMA, SMB, PC ou SVT)
- MG : moyenne générale.
- FS (formule spécifique) : un réel déjà calculé à partir des notes obtenues dans les diverses matières.
- i : un réel=1 si l’élève est redoublant en BAC et 1.10 sinon
On souhaite réaliser les fonctions suivantes :
- formule_gen() qui permet de créer un autre fichier ‘PSI_FG.txt’, à partir du fichier ‘PSI.txt’, et y stocker, pour les mêmes bacheliers, les informations suivantes : Num_insc, NP, FILIERE et FG. Sachant que la formule globale (FG) de chaque élève est calculée par l’équation :
FG=((5*MG+FS)*i) - classer() qui permet de classer les bacheliers du fichiers ‘PSI_FG.txt’ par ordre décroissant selon la formule globale(FG).
N.B : pour faire cette tache, on doit transmettre les informations dans un tableau, les trier puis les transmettre ordonnées dans le fichier, implémenter un algorithme de tri que vous voulez pour trier le tableau - generer() qui permet d’extraire, dans le même répertoire, 4 autres fichiers (‘PSI_princ.txt’, ‘PSI_t1.txt’, ‘PSI_t2.txt’, ‘PSI_t3.txt’) contenant respectivement les bacheliers appartenant au groupe liste principale, tranche 1, tranche2 et tranche3.
- afficher(Num_insc) qui permet d’afficher, pour un candidat donné, en fonction de son numéro d’inscription (donnée fournie en argument), le groupe auquel il appartient
Solution :
def formule_gen(): source = open("PSI.txt") dest = open("PSI_FG.txt", "a") for ligne in source: s = ligne.strip() tab = s.split(":") fg = ((5*float(tab[3])+float(tab[4]))*float(tab[5])) etd = str(tab[0])+":"+str(tab[1])+":"+str(tab[2])+":"+str(fg)+"\n" dest.write(etd) source.close() dest.close() def classer(): source = open("PSI_FG.txt") L = source.readlines() for i in range(len(L)-1): m = i for j in range(i+1, len(L)): t1 = L[j].strip().split(":") t2 = L[m].strip().split(":") if float(t1[3]) > float(t2[3]): m = j L[i], L[m] = L[m], L[i] source.close() source = open("PSI_FG.txt", "w") source.writelines(L) source.close() def generer(): l1 = [] # SMA l2 = [] # SMB l3 = [] # PC l4 = [] # SVT # classer() # classer dans 3 listes les etudiants selon la filiere source = open("PSI_FG.txt") for ligne in source: t = ligne.split(":") if t[2] == "SMA": l1.append(ligne) elif t[2] == "SMB": l2.append(ligne) elif t[2] == "PC": l3.append(ligne) else: l4.append(ligne) source.close() # construire la liste principale nb1 = 12 # nombre des etudiants SMA nb2 = 9 # nombre des etudiants SMB nb3 = 6 # nombre des etudiants PC nb4 = 3 # nombre des etudiants SVT isma = 0 # indice de debut pour SMA ismb = 0 # indice de debut pour SMB ipc = 0 # indice de debut pour PC isvt = 0 # indice de debut pour SVT princ = open("PSI_princ.txt", "a") for i in range(nb1): if i < len(l1): princ.write(l1[i]) for i in range(nb2): if i < len(l2): princ.write(l2[i]) for i in range(nb3): if i < len(l3): princ.write(l3[i]) for i in range(nb4): if i < len(l4): princ.write(l4[i]) princ.close() # construire la tranche 1 isma = nb1 ismb = nb2 ipc = nb3 isvt = nb4 nb1 += 20 nb2 += 10 nb3 += 8 nb4 += 2 princ = open("PSI_t1.txt", "a") for i in range(isma, nb1): if i < len(l1): princ.write(l1[i]) for i in range(ismb, nb2): if i < len(l2): princ.write(l2[i]) for i in range(ipc, nb3): if i < len(l3): princ.write(l3[i]) for i in range(isvt, nb4): if i < len(l4): princ.write(l4[i]) princ.close() # construire la tranche 2 isma = nb1 ismb = nb2 ipc = nb3 isvt = nb4 nb1 += 24 nb2 += 18 nb3 += 12 nb4 += 6 princ = open("PSI_t2.txt", "a") for i in range(isma, nb1): if i < len(l1): princ.write(l1[i]) for i in range(ismb, nb2): if i < len(l2): princ.write(l2[i]) for i in range(ipc, nb3): if i < len(l3): princ.write(l3[i]) for i in range(isvt, nb4): if i < len(l4): princ.write(l4[i]) princ.close() # construire la tranche 3 isma = nb1 ismb = nb2 ipc = nb3 nb1 += 27 nb2 += 12 nb3 += 11 princ = open("PSI_t3.txt", "a") for i in range(isma, nb1): if i < len(l1): princ.write(l1[i]) for i in range(ismb, nb2): if i < len(l2): princ.write(l2[i]) for i in range(ipc, nb3): if i < len(l3): princ.write(l3[i]) for i in range(isvt, nb4): if i < len(l4): princ.write(l4[i]) princ.close() def afficher(Num_insc): princ = open("PSI_princ.txt") L1 = princ.readlines() tr1 = open("PSI_t1.txt") L2 = tr1.readlines() tr2 = open("PSI_t2.txt") L3 = tr2.readlines() tr3 = open("PSI_t3.txt") L4 = tr3.readlines() etat = False tranche = "" # chercher dans la liste principale for ligne in L1: if str(Num_insc) == ligne[:len(str(Num_insc))]: etat = True tranche = "Liste principale" break # si l etudiant n appartient pas a liste principale rechercher dans la tranche 1 if etat == False: for ligne in L2: if str(Num_insc) == ligne[:len(str(Num_insc))]: etat = True tranche = "Tranche 1" break # si l"etudiant n appartient pas a tranche 1 rechercher dans la tranche 2 if etat == False: for ligne in L3: if str(Num_insc) == ligne[:len(str(Num_insc))]: etat = True tranche = "Tranche 2" break # si l"etudiant n appartient pas a tranche 2 rechercher dans la tranche 3 if etat == False: for ligne in L4: if str(Num_insc) == ligne[:len(str(Num_insc))]: etat = True tranche = "Tranche 3" break return (etat, tranche)