Risoluzione Tracce di Esame II Modulo

Da Bioingegneria Elettronica e Informatica.


Appello 27 Giugno 2017

Esercizio 2: Si ha la necessità di definire tre classi in Python: persona, studente, lavoratore. Le ultime due classi elencate, ovvero studente e lavoratore sono classe derivate dalla classe persona. Scrivere il codice Python che permette di definire le tre classi su elencate (tenendo conto del concetto di ereditarietà) e un piccolo main che ne richiama i metodi definiti. NOTA IMPORTANTE: si definiscano solo gli attributi (3 per la classe persona, 1 specifico di studente, 1 specifico di lavoratore) e i metodi init e str.

Codice Python Di seguito il codice python che modella l'ereditarietà tra le classi.

  1. class Persona:
  2.     def __init__(self, nome, indirizzo, eta):
  3.         self.__nome = nome
  4.         self.__indirizzo = indirizzo
  5.         self.__eta = eta
  6.  
  7.     def __str__(self):
  8.         return "Nome: "+self.__nome+", Indirizzo: "+self.__indirizzo+", Età: "+ str(self.__eta)
  9.  
  10.  
  11. class Studente(Persona):
  12.     def __init__(self, nome, indirizzo, eta, voto):
  13.         Persona.__init__(self, nome, indirizzo, eta)
  14.         self.__voto = voto
  15.  
  16.     def __str__(self):
  17.         return Persona.__str__(self)+", Voto: "+ str(self.__voto)
  18.  
  19.  
  20. class Lavoratore(Persona):
  21.     def __init__(self, nome, indirizzo, eta, stipendio):
  22.         Persona.__init__(self, nome, indirizzo, eta)
  23.         self.__stipendio = stipendio
  24.  
  25.     def __str__(self):
  26.         return Persona.__str__(self)+", Stipendio: "+ str(self.__stipendio)

Di seguito la funzione Main che richiama i metodi definiti.

  1. import ereditarieta
  2.  
  3. def main():
  4.     p = ereditarieta.Persona("Paolo", "Via Italia, 5", 34)
  5.     s = ereditarieta.Studente("Antonio", "Via delle Camelie, 19", 14, 7)
  6.     l = ereditarieta.Lavoratore("Marco", "Piazza Garibaldi, 2", 54, 1000)
  7.     print(p)
  8.     print(s)
  9.     print(l)
  10.  
  11. main()

Esercizio 3: Si ha la necessità di leggere da file (.txt) i nomi dei dipendenti e il monte ore (numero non intero) degli stessi.

In particolare, il file è strutturato nel seguente modo:

Es3 image.png

I nominativi e i monte ore dovranno essere caricati prima in due liste distinte e successivamente ricopiate in un dizionario avente come chiave il nominativo e come elemento il monte ore. Il programma termina, dopo gli opportuni salvataggi, con la stampa a schermo dei nominativi con annesso monte ore e paga lorda (N.B. la paga lorda va calcolata basandosi su un costo orario unico per tutti i dipendenti acquisito da tastiera) secondo il seguente esempio: Nominativo dipendente: Paolo Rossi 47.8 ore lavorate Costo orario: 12.37 € Paga lorda: € 591.28 Nominativo dipendente: Luigi Bianchi 25.4 ore lavorate Costo orario: 12.37 € Paga lorda: € 314.20 …

Scrivere il codice Python, opportunamente strutturato in funzioni, dell’algoritmo che:

  1. acquisisce da tastiera il nome del file da leggere;
  2. legge il file e carica sia la lista dei nominativi che quella del monte ore;
  3. carica il dizionario con i dati inseriti nelle due liste;
  4. salva su file binario il dizionario;
  5. acquisisce da tastiera il costo orario uguale per tutti i dipendenti;
  6. stampa a schermo le informazioni contenute nel dizionario secondo il formato riportato in precedenza;
  7. gestisce le eccezioni che possono essere sollevate.

Codice Python Di seguito il codice python che implementa quanto richiesto.

  1. import pickle
  2.  
  3. def carica_dati():
  4.     try:
  5.         #infile = open('dati.txt','r')
  6.         namefile = input('Inserire il nome del file e la sua estensione: ')
  7.         infile = open(namefile,'r')
  8.         dati = infile.readlines()
  9.         infile.close()
  10.     except Exception as err:
  11.         dati = list()
  12.         print("File non esistente")
  13.         return dati
  14.     else:
  15.         return dati
  16.  
  17. def carica_liste(dati):
  18.     nominativi = list()
  19.     ore= list()
  20.     for i in range(0,len(dati),2):
  21.         nominativi.append(dati[i].rstrip('\n'))
  22.         ore.append(float(dati[i+1].rstrip('\n')))
  23.     return nominativi, ore
  24.  
  25. def carica_dizionario(n, o):
  26.     d = dict()
  27.     for i in range(0,len(n)):
  28.         d[n[i]] = o[i]
  29.     return d
  30.  
  31. def salva_dizionario(d):
  32.     file = open('log.dat','wb')
  33.     pickle.dump(d, file)
  34.     file.close()
  35.  
  36. def visualizza_info(d, paga_oraria):
  37.     for key in d:
  38.         totale = d[key]*paga_oraria
  39.         print("Nominativo dipendente: "+key+"\t"+ str(d[key]) + " ore lavorate\t Costo orario: "+str(paga_oraria)+ "€\t Paga lorda € "+str(totale))
  40.  
  41.  
  42. def main():
  43.     dati = carica_dati()
  44.     if (len(dati)>0):
  45.  
  46.         try:
  47.  
  48.             nominativi, ore = carica_liste(dati)
  49.  
  50.             monte_ore_lav = carica_dizionario(nominativi, ore)
  51.  
  52.             paga_oraria = float(input('Inserire la paga oraria in Euro: '))
  53.  
  54.             salva_dizionario(monte_ore_lav)
  55.             visualizza_info(monte_ore_lav, paga_oraria)
  56.  
  57.         except Exception as err:
  58.             print(err)
  59.  
  60. main()

Esercizio 4: Si ha la necessità di definire una classe di punti 3D. Scrivere il programma Python che permette di definire la classe, gli attributi e i metodi che:

  1. inizializzano il punto con una posizione predefinita;
  2. restituiscono in una stringa le coordinate del punto;
  3. permettono di spostare le coordinate del punto indicando la nuova posizione;
  4. permettono di calcolare la distanza tra due punti;
  5. permettono di effettuare un controllo (vero/falso) dati tre punti (vedi nota importante 2).

Scrivere, inoltre, un breve main che mostri il funzionamento dei metodi definiti.

NOTA IMPORTANTE 1: il metodo che permette di implementare il punto d) deve essere richiamato nel seguente modo: a.calcola_distanza(b) dove a e b sono due punti 3D, mentre il metodo che permette di implementare il punto e) deve essere richiamato nel seguente modo: a.check_condition(b,c) dove a,b e c sono tre punti 3D. NOTA IMPORTANTE 2: Il controllo da effettuare è il seguente. Dati i tre segmenti di misure A (es. a-b), B (es. b-c), C (es. a-c) calcolate grazie alle coordinate dei tre punti, il controllo restituirà valore vero nella seguente condizione: ciascun segmento deve essere minore della somma degli altri due e maggiore della loro differenza, ovvero si devono verificare tutte le seguenti condizioni:

Es4 image.png

AIUTO: a-b è equivalente alla distanza tra due punti; la funzione che permette di calcolare il valore assoluto è fabs

Codice Python Di seguito il codice python che definisce la classe di punti 3D.

  1. import math
  2. class Punto3D:
  3.     def __init__(self,x,y,z):
  4.         self.__x = x
  5.         self.__y = y
  6.         self.__z = z
  7.  
  8.     def calc_dist(self, b):
  9.         x= quadrato_differenza(self.__x,b.get_x())
  10.         y= quadrato_differenza(self.__y,b.get_y())
  11.         z= quadrato_differenza(self.__z,b.get_z())
  12.         return math.sqrt(x+y+z)
  13.  
  14.     def set_pos(self,x,y,z):
  15.         self.__x = x
  16.         self.__y = y
  17.         self.__z = z
  18.  
  19.     def get_x(self):
  20.         return self.__x
  21.  
  22.     def get_y(self):
  23.         return self.__y
  24.  
  25.     def get_z(self):
  26.         return self.__z
  27.  
  28.     def __str__(self):
  29.          return "(x: "+str(self.__x) + ", y: "+str(self.__y)+", z: "+str(self.__z)+")"
  30.  
  31.     def check_condition(self,b,c):
  32.         A = self.calc_dist(b)
  33.         B = b.calc_dist(c)
  34.         C = self.calc_dist(c)
  35.         if (A<B+C) and (B<A+C) and (C<A+B) and (A>math.fabs(B-C)) and (B>math.fabs(A-C)) and (C>math.fabs(A-B)):
  36.             return True
  37.         else:
  38.             return False
  39.  
  40.  
  41.  
  42. def quadrato_differenza(a,b):
  43.     return (a-b)**2

Di seguito la funzione main che mostra il funzionamento dei metodi definiti.

  1. import punto
  2.  
  3.  
  4. def main():
  5.     a = punto.Punto3D(0.0,0.0,0.0)
  6.     b = punto.Punto3D(1.0,0.0,0.0)
  7.     c = punto.Punto3D(1.0,1.0,1.0)
  8.  
  9.     print("a")
  10.     print(a)
  11.     print()
  12.     print("b")
  13.     print(b)
  14.     print()
  15.     print("c")
  16.     print(c)
  17.     print()
  18.     print("distanza tra a e b\t" + str(a.calc_dist(b)))
  19.     print("distanza tra a e c\t" + str(a.calc_dist(c)))
  20.  
  21.  
  22.     if (a.check_condition(b,c)):
  23.         print("condizione vera tra a,b e c")
  24.     else:
  25.         print("condizione falsa tra a,b e c")
  26.  
  27.     a.set_pos(1,2,3)
  28.     print("nuova posizione di a")
  29.     print(a)
  30.  
  31. main()


Appello 26 Luglio 2017

Esercizio 2: Si ha la necessità di definire quattro classi in Python: animale, mammifero, gatto, cane. Le classi elencate sono in relazioni diverse tra loro. Scrivere il codice Python che permette di definire le quattro classi su elencate (tenendo conto del concetto di ereditarietà) e un piccolo main che ne richiama i metodi definiti. NOTA IMPORTANTE: si definiscano solo gli attributi (almeno 3 per la classe base e almeno uno per ogni classe derivata) e i metodi init e str.

Codice Python Di seguito il codice python che modella l'ereditarietà tra le classi.

  1. class Animale:
  2.     def __init__(self, alimentazione, tipo, eta):
  3.         self.__alimentazione = alimentazione
  4.         self.__tipo = tipo
  5.         self.__eta = eta
  6.  
  7.     def __str__(self):
  8.         return "Alimentazione: "+self.__alimentazione+", Tipo: "+self.__tipo+", Eta': "+ str(self.__eta)
  9.  
  10. class Mammifero(Animale):
  11.     def __init__(self, alimentazione, tipo, eta, zampe):
  12.         Animale.__init__(self, alimentazione, tipo, eta)
  13.         self.__zampe = zampe
  14.  
  15.     def __str__(self):
  16.         return Animale.__str__(self)+", Numero zampe: "+ str(self.__zampe)
  17.  
  18. class Cane(Mammifero):
  19.     def __init__(self, alimentazione, tipo, eta, zampe, razza):
  20.         Mammifero.__init__(self, alimentazione, tipo, eta, zampe)
  21.         self.__razza = razza
  22.  
  23.     def __str__(self):
  24.         return Mammifero.__str__(self)+", Razza: "+ str(self.__razza)
  25.  
  26. class Gatto(Mammifero):
  27.     def __init__(self, alimentazione, tipo, eta, zampe, razza):
  28.         Mammifero.__init__(self, alimentazione, tipo, eta, zampe)
  29.         self.__razza = razza
  30.  
  31.     def __str__(self):
  32.         return Mammifero.__str__(self)+", Razza: "+ str(self.__razza)

Di seguito la funzione Main che richiama i metodi definiti.

  1. import ereditarieta
  2.  
  3. def main():
  4.     a = ereditarieta.Animale("onnivoro", "acquatico", 3)
  5.     m = ereditarieta.Mammifero("erbivoro", "terrestre", 20, 4)
  6.     c = ereditarieta.Cane("carnivoro", "terrestre", 10, 4, "Labrador")
  7.     g = ereditarieta.Gatto("carnivoro", "terrestre", 7, 4, "Persiano")
  8.     print(a)
  9.     print(m)
  10.     print(c)
  11.     print(g)
  12.  
  13. main()

Esercizio 3: Si ha la necessità di leggere da file (.txt) i nomi degli studenti e i voti ottenuti (numero intero) nei due moduli dell’esame di informatica.

In particolare, il file è strutturato nel seguente modo:

Es3 2.png

I nominativi e la media dei due voti relativi a tale nominativo dovranno essere caricati prima in due liste distinte e successivamente ricopiate in un dizionario avente come chiave il nominativo e come elemento la media dei voti. Il programma termina, dopo gli opportuni salvataggi, con la stampa a schermo dei nominativi con annessi voti, media esami e risultato dell’esame (Superato/Non Superato) secondo il seguente esempio:

Nominativo dipendente: Paolo Rossi Media voti: 27,5 Esame superato

Nominativo dipendente: Luigi Bianchi Media voti: 17 Esame non superato

Scrivere il codice Python, opportunamente strutturato in funzioni, dell’algoritmo che:

  1. acquisisce da tastiera il nome del file da leggere;
  2. legge il file e carica sia la lista dei nominativi che quella delle medie dei voti;
  3. carica il dizionario con i dati inseriti nelle due liste;
  4. salva su file binario il dizionario;
  5. stampa a schermo le informazioni contenute nel dizionario secondo il formato riportato in precedenza;
  6. stampa a schermo un secondo elenco contenente solo i nomi di coloro che hanno superato l’esame;
  7. gestisce le eccezioni che possono essere sollevate.

Codice Python Di seguito il codice python che implementa quanto richiesto.

  1. import pickle
  2.  
  3. def carica_dati():
  4.     try:
  5.         #infile = open('dati.txt','r')
  6.         namefile = input('Inserire il nome del file e la sua estensione: ')
  7.         infile = open(namefile,'r')
  8.         dati = infile.readlines()
  9.         infile.close()
  10.     except Exception as err:
  11.         dati = list()
  12.         print("File non esistente")
  13.     return dati
  14.  
  15. def carica_liste(dati):
  16.     nominativi = list()
  17.     medie = list()
  18.     for i in range(0,len(dati),3):
  19.         nominativi.append(dati[i].rstrip('\n'))
  20.         medie.append([(float(dati[i + 1].rstrip('\n')) + float(dati[i + 2].rstrip('\n')))//2])
  21.     return nominativi, medie
  22.  
  23. def carica_dizionario(n, m):
  24.     d = dict()
  25.     for i in range(0,len(n)):
  26.         d[n[i]] = m[i]
  27.     return d
  28.  
  29. def salva_dizionario(d):
  30.     file = open('voti.dat','wb')
  31.     pickle.dump(d, file)
  32.     file.close()
  33.  
  34. def visualizza_info1(nominativo_media_d):
  35.     for key in nominativo_media_d:
  36.         print("Nominativo studente: "+key+"\t"+ " Media voti: "+str(nominativo_media_d[key]),end='')
  37.         if nominativo_media_d[key][0] < 18:
  38.             print("\t Esame non superato")
  39.         else:
  40.             print("\t Esame superato")
  41.  
  42. def visualizza_info2(nominativo_media_d):
  43.     print("Esame superato da:")
  44.     for key in nominativo_media_d:
  45.         if nominativo_media_d[key][0] >= 18:
  46.             print(key)
  47.  
  48. def main():
  49.     dati = carica_dati()
  50.     if (len(dati)>0):
  51.         try:
  52.             nominativi, medie = carica_liste(dati)
  53.             nominativo_media_d = carica_dizionario(nominativi, medie)
  54.             salva_dizionario(nominativo_media_d)
  55.             visualizza_info1(nominativo_media_d)
  56.             visualizza_info2(nominativo_media_d)
  57.         except Exception as err:
  58.             print(err)
  59.  
  60. main()

Esercizio 4: Si ha la necessità di definire una classe di triangoli 2D e una classe di punti 2D (che costituiranno i vertici del triangolo). Scrivere il programma Python che permette di definire le classi, gli attributi e i metodi che:

  1. inizializzano il triangolo con le posizioni dei 3 vertici;
  2. restituiscono in una stringa le coordinate dei vertici;
  3. permettono di calcolare il perimetro del triangolo;
  4. permettono di controllare se i tre vertici del triangolo possono essere effettivamente i vertici di un triangolo.

Scrivere, inoltre, un breve main che mostri il funzionamento dei metodi definiti.

NOTA IMPORTANTE 1: Il metodo che permette di implementare il punto d) deve essere richiamato nel seguente modo: t.check_triangle() dove t è un triangolo 2D.

NOTA IMPORTANTE 2: Dati tre segmenti di misure A (es. a-b), B (es. b-c), C (es. a-c), dove a, b e c sono i vertici contenuti nell’oggetto triangolo, per poterci effettivamente costruire un triangolo si deve verificare la seguente condizione: ciascun segmento deve essere minore della somma degli altri due e maggiore della loro differenza.

Es4 2.png

AIUTO: a-b è equivalente alla distanza tra due punti; la funzione che permette di calcolare il valore assoluto è fabs

Codice Python Di seguito il codice python che definisce la classe di punti 2D.

  1. import math
  2.  
  3. class Punto2D:
  4.     def __init__(self,x,y):
  5.         self.__x = x
  6.         self.__y = y
  7.  
  8.     def calc_dist(self, b):
  9.         x= quadrato_differenza(self.__x, b.get_x())
  10.         y= quadrato_differenza(self.__y, b.get_y())
  11.         return math.sqrt(x+y)
  12.  
  13.     def get_x(self):
  14.         return self.__x
  15.  
  16.     def get_y(self):
  17.         return self.__y
  18.  
  19.     def __str__(self):
  20.          return "(x: "+str(self.__x) + ", y: "+str(self.__y)+")"
  21.  
  22. def quadrato_differenza(a, b):
  23.     return (a-b)**2

Di seguito il codice python che definisce la classe Triangolo.

  1. import math
  2.  
  3. class Triangolo:
  4.     def __init__(self, a, b, c):
  5.         self.__a = a
  6.         self.__b = b
  7.         self.__c = c
  8.  
  9.     def __str__(self):
  10.         return "Vertice A: " + str(self.__a) + " Vertice B: " + str(self.__b) + " Vertice C: " + str(self.__c)
  11.  
  12.     def check_triangle(self):
  13.         A = self.__a.calc_dist(self.__b)
  14.         B = self.__b.calc_dist(self.__c)
  15.         C = self.__c.calc_dist(self.__a)
  16.         if (A<B+C) and (B<A+C) and (C<A+B) and (A>math.fabs(B-C)) and (B>math.fabs(A-C)) and (C>math.fabs(A-B)):
  17.             return True
  18.         else:
  19.             return False
  20.  
  21.     def perimetro(self):
  22.         return self.__a.calc_dist(self.__b) + self.__b.calc_dist(self.__c) + self.__c.calc_dist(self.__a)

Di seguito la funzione main che mostra il funzionamento dei metodi definiti.

  1. from punto2d import Punto2D as punto
  2. from triangolo import Triangolo
  3.  
  4. def main():
  5.     a = punto(0, 0)
  6.     b = punto(1, 0)
  7.     c = punto(0, 1)
  8.  
  9.     t = Triangolo(a, b, c)
  10.     print(t)
  11.     print(t.perimetro())
  12.     print(t.check_triangle())
  13.  
  14.  
  15. main()


Appello 7 Settembre 2017

Esercizio 2: Si ha la necessità di definire quattro classi in Python: gatto, animale, felino, mammifero. Le classi elencate sono in relazioni diverse tra loro. Scrivere il codice Python che permette di definire le quattro classi su elencate (tenendo conto del concetto di ereditarietà) e un piccolo main che ne richiama i metodi definiti.

NOTA IMPORTANTE: si definiscano solo: gli attributi (almeno due per ogni classe); i metodi init e str per ogni classe.

Codice Python Di seguito il codice python che modella l'ereditarietà tra le classi.

  1. class Animale:
  2.     def __init__(self, alimentazione, tipo):
  3.         self.__alimentazione = alimentazione
  4.         self.__tipo = tipo
  5.  
  6.     def __str__(self):
  7.         return "Alimentazione: "+self.__alimentazione+", Tipo: "+self.__tipo
  8.  
  9. class Mammifero(Animale):
  10.     def __init__(self, alimentazione, tipo, eta, zampe):
  11.         Animale.__init__(self, alimentazione, tipo)
  12.         self.__eta = eta
  13.         self.__zampe = zampe
  14.  
  15.     def __str__(self):
  16.         return Animale.__str__(self)+", Etá: "+ str(self.__eta)+", Numero zampe: "+ str(self.__zampe)
  17.  
  18. class Felino(Mammifero):
  19.     def __init__(self, alimentazione, tipo, eta, zampe, dimensione, provenienza):
  20.         Mammifero.__init__(self, alimentazione, tipo, eta, zampe)
  21.         self.__dimensione = dimensione
  22.         self.__provenienza = provenienza
  23.  
  24.     def __str__(self):
  25.         return Mammifero.__str__(self)+", Dimensione: "+ self.__dimensione+", Provenienza: "+ self.__provenienza
  26.  
  27. class Gatto(Felino):
  28.     def __init__(self, alimentazione, tipo, eta, zampe, dimensione, provenienza, verso, pelo):
  29.         Felino.__init__(self, alimentazione, tipo, eta, zampe, dimensione, provenienza)
  30.         self.__verso = verso
  31.         self.__pelo = pelo
  32.  
  33.     def __str__(self):
  34.         return Felino.__str__(self)+", Verso: "+ self.__verso+", Pelo: "+ self.__pelo

Di seguito la funzione main che mostra il funzionamento dei metodi definiti.

  1. import ereditarieta
  2.  
  3. def main():
  4.     a = ereditarieta.Animale("onnivoro", "acquatico")
  5.     m = ereditarieta.Mammifero("erbivoro", "terrestre", 20, 4)
  6.     c = ereditarieta.Felino("carnivoro", "terrestre", 10, 4, "Taglia grande", "Africa")
  7.     g = ereditarieta.Gatto("carnivoro", "terrestre", 7, 4, "Taglia piccola", "Europa", "Miagolio", "Pelo Lungo")
  8.     print(a)
  9.     print(m)
  10.     print(c)
  11.     print(g)
  12.  
  13. main()


Esercizio 3: Si ha la necessità di leggere da file (.txt) le coordinate x, y, z di punti 3D e di calcolarne il baricentro. In particolare, il file delle coordinate è strutturato nel seguente modo:

D563b14e9d0ab84d9f8010b2224d44df.png

Scrivere il codice Python dell’algoritmo che :

  1. definisce la classe dei punti 3D;
  2. acquisisce da tastiera il nome del file da leggere;
  3. legge il file e carica la lista di punti 3D;
  4. calcola il baricentro dei punti 3D a partire dalla lista di punti;
  5. stampa a schermo le coordinate del baricentro (inteso come ulteriore punto 3D);
  6. gestisce le eccezioni che possono essere sollevate;
  7. richiama le funzioni viste (main).

Lista punti d'esempio punti.txt

0.0
0.0
0.0
1.0
1.0
1.0
2.0
2.0
2.0
3.0
3.0
3.0
4.0
4.0
4.0
5.0
5.0
5.0

Codice Python Di seguito il codice python che modella l'ereditarietà tra le classi.

  1. import math
  2. class Punto3D:
  3.     def __init__(self,x,y,z):
  4.         self.__x = x
  5.         self.__y = y
  6.         self.__z = z
  7.  
  8.     def set_pos(self,x,y,z):
  9.         self.__x = x
  10.         self.__y = y
  11.         self.__z = z
  12.  
  13.     def get_x(self):
  14.         return self.__x
  15.  
  16.     def get_y(self):
  17.         return self.__y
  18.  
  19.     def get_z(self):
  20.         return self.__z
  21.  
  22.     def __str__(self):
  23.          return "(x: "+str(self.__x) + ", y: "+str(self.__y)+", z: "+str(self.__z)+")"

Di seguito la funzione main che mostra il funzionamento dei metodi definiti.

  1. import punto3d
  2.  
  3. def carica_dati():
  4.     try:
  5.         namefile = input('Inserire il nome del file e la sua estensione: ')
  6.         infile = open(namefile,'r')
  7.         dati = infile.readlines()
  8.         infile.close()
  9.     except Exception as err:
  10.         dati = list()
  11.         print("File non esistente")
  12.     return dati
  13.  
  14.  
  15. def carica_lista_punti(dati):
  16.     lista_punti = list()
  17.     for i in range(0,len(dati),3):
  18.         x = float(dati[i].rstrip('\n'))
  19.         y = float(dati[i+1].rstrip('\n'))
  20.         z = float(dati[i+2].rstrip('\n'))
  21.         p = punto3d.Punto3D(x,y,z)
  22.         lista_punti.append(p)
  23.     return lista_punti
  24.  
  25.  
  26. def calcola_baricentro(lista):
  27.     x = 0.0
  28.     y = 0.0
  29.     z = 0.0
  30.     for i in lista:
  31.         x+=i.get_x()
  32.         y+=i.get_y()
  33.         z+=i.get_z()
  34.     n = len(lista)
  35.     baricentro = punto3d.Punto3D(x/n,y/n,z/n)
  36.     return baricentro
  37.  
  38.  
  39. def main():
  40.     dati = carica_dati()
  41.     if (len(dati)>0):
  42.         try:
  43.             lista_punti = carica_lista_punti(dati)
  44.             print("Il baricentro dei punti contenuti nel file e'"+str(calcola_baricentro(lista_punti)))
  45.         except Exception as err:
  46.             print(err)
  47.  
  48. main()

Esercizio 4: Si ha la necessità di gestire un campionato sportivo. In particolare, il campionato dovrà essere modellato come una classe (in modo tale da poter istanziare campionati di diverse nazionalità) che contiene le due informazioni fondamentali di ciascuna squadra del campionato: il nome e il punteggio ottenuto in campionato. Non possono esserci due squadre con lo stesso nome all’interno dello stesso campionato. NOTA: selezionare in modo opportuno la struttura dati che dovrà contenere le due informazioni relative a ciascuna squadra e che dovrà essere contenuta nella classe campionato.

Scrivere il programma Python che permette di definire le classi, gli attributi, le strutture dati e i metodi che:

  1. inizializzano il campionato con un certo numero di squadre deciso dall’utente;
  2. permettono di stabilire la squadra vincitrice del campionato e di visualizzarne le informazioni a schermo;
  3. permettono di stabilire le ultime tre squadre in classifica e di visualizzarne le informazioni a schermo.

Scrivere, inoltre, un breve main che mostri il funzionamento dei metodi definiti.

Codice Python

  1. class Campionato:
  2.  
  3.     def __init__(self):
  4.         self.__s = dict()
  5.  
  6.     def add_team(self, nome, punteggio):
  7.         self.__s[nome] = punteggio
  8.  
  9.     def get_team(self, nome):
  10.         self.__s.get(nome,-10)
  11.  
  12.     def delete_team(self, nome):
  13.         self.__s.pop(nome, 0)
  14.  
  15.     def get_first_team(self):
  16.         if len(self.__s)>0:
  17.             m=max(self.__s.values())
  18.             for key in self.__s:
  19.                 if self.__s[key]==m:
  20.                     return key, m
  21.         else:
  22.             return "",0
  23.  
  24.     def get_last_team(self):
  25.         if len(self.__s)>0:
  26.             m=min(self.__s.values())
  27.             for key in self.__s:
  28.                 if self.__s[key]==m:
  29.                     return key, m
  30.         else:
  31.             return "",0
  32.  
  33.     def get_number_of_team(self):
  34.         return len(self.__s)
  35.  
  36.     def __str__(self):
  37.         return str(self.__s)

Di seguito la funzione main che mostra il funzionamento dei metodi definiti.

  1. import campionato
  2.  
  3. def main():
  4.     c = campionato.Campionato()
  5.     n = int(input("Da quante squadre e' composto il campionato? "))
  6.     for i in range(0,n):
  7.         nome_squadra = input("Inserire il nome della squadra: ")
  8.         punteggio = int(input("Inserire il punteggio ottenuto dalla squadra "+nome_squadra+": "))
  9.         c.add_team(nome_squadra, punteggio)
  10.     print("Il campionato e' formato da "+str(c.get_number_of_team())+" squadre")
  11.     if c.get_number_of_team()>1:
  12.         squadra, p = c.get_first_team()
  13.         print("La squadra che ha vinto il campionato e' "+squadra+" con un punteggio di "+str(p)+" punti")
  14.     if c.get_number_of_team()>0:
  15.         print("Le ultime 3 squadre del campionato sono:")
  16.         #s servirá per ripristinare tutte le squadre cancellate 
  17.         s = dict()
  18.         for i in range(0,3):
  19.             squadra, p = c.get_last_team()
  20.             s[squadra]=p
  21.             c.delete_team(squadra)
  22.             print(squadra+" con un punteggio di "+str(p)+" punti")
  23.  
  24.         #ripristina lo stato del campionato
  25.         for k in s:
  26.             c.add_team(k, s[k])
  27.  
  28.     #verifichiamo che il numero delle squadre e lo stato del campionato sia lo stesso di quello iniziale
  29.     print("Il campionato e' formato da "+str(c.get_number_of_team())+" squadre")
  30.     print(c)
  31.  
  32. main()


Appello 27 Settembre 2017

Esercizio 2: Si ha la necessità di definire tre classi in Python: operaio, persona, lavoratore. Le classi elencate sono in relazioni diverse tra loro. Scrivere il codice Python che permette di definire le tre classi su elencate (tenendo conto del concetto di ereditarietà) e un piccolo main che ne richiama i metodi definiti.

NOTA IMPORTANTE: si definiscano solo: gli attributi (almeno due per ogni classe); i metodi init, get/set e str per ogni classe.

Codice Python Di seguito il codice python che modella l'ereditarietà tra le classi.

  1. class Persona:
  2.     def __init__(self, eta, altezza):
  3.         self.__eta = eta
  4.         self.__altezza = altezza
  5.  
  6.     def get_eta(self):
  7.         return self.__eta
  8.  
  9.     def set_eta(self, eta):
  10.         self.__eta = eta
  11.  
  12.     def get_altezza(self):
  13.         return self.__altezza
  14.  
  15.     def set_altezza(self, altezza):
  16.         self.__altezza = altezza
  17.  
  18.     def __str__(self):
  19.         return "Etá: "+str(self.__eta)+", Altezza: "+str(self.__altezza)
  20.  
  21. class Lavoratore(Persona):
  22.     def __init__(self, eta, altezza, stipendio, ore_lav):
  23.         Persona.__init__(self, eta, altezza)
  24.         self.__stipendio = stipendio
  25.         self.__ore_lav = ore_lav
  26.  
  27.     def get_stipendio(self):
  28.         return self.__stipendio
  29.  
  30.     def set_stipendio(self, stipendio):
  31.         self.__stipendio = stipendio
  32.  
  33.     def get_ore_lav(self):
  34.         return self.__ore_lav
  35.  
  36.     def set_ore_lav(self, ore_lav):
  37.         self.__ore_lav = ore_lav
  38.  
  39.     def __str__(self):
  40.         return Persona.__str__(self)+", Stipendio: "+ str(self.__stipendio)+", Ore lavorate: "+ str(self.__ore_lav)
  41.  
  42. class Operaio(Lavoratore):
  43.     def __init__(self, eta, altezza, stipendio, ore_lav, mansione, unita):
  44.         Lavoratore.__init__(self, eta, altezza, stipendio, ore_lav)
  45.         self.__mansione = mansione
  46.         self.__unita = unita
  47.  
  48.     def get_mansione(self):
  49.         return self.__mansione
  50.  
  51.     def set_mansione(self, mansione):
  52.         self.__mansione = mansione
  53.  
  54.     def get_unita(self):
  55.         return self.__unita
  56.  
  57.     def set_unita(self, unita):
  58.         self.__unita = unita
  59.  
  60.     def __str__(self):
  61.         return Lavoratore.__str__(self)+", Mansione: "+ self.__mansione+", Unitá: "+ self.__unita

Di seguito la funzione main che mostra il funzionamento dei metodi definiti.

  1. import ereditarieta
  2.  
  3. def main():
  4.     a = ereditarieta.Persona(15, 145)
  5.     m = ereditarieta.Lavoratore(19, 170, 1000, 160)
  6.     c = ereditarieta.Operaio(35, 175, 1500, 180, "Movimentazione", "Auto")
  7.  
  8.     print(a)
  9.     print(m)
  10.     print(c)
  11.     print(c.get_altezza())
  12.     m.set_stipendio(1450)
  13.     print(m)
  14.  
  15. main()


Esercizio 3: Si ha la necessità di gestire un’agenzia immobiliare. In particolare, ogni casa in gestione all’agenzia immobiliare ha un suo codice univoco alfanumerico e diverse informazioni (circa 6) tra cui il prezzo di vendita. La tipica richiesta rivolta all’operatore dell’agenzia immobiliare è quella di trovare le case all’interno di un range di prezzo.

  1. definisce un oggetto casa con le informazioni ad essa relative;
  2. inizializza le informazioni di cui al punto precedente;
  3. gestisce il dizionario delle case ed i codici identificativi delle stesse;
  4. salva su file binario tutte le case;
  5. stampa a schermo il catalogo case gestite dall’agenzia immobiliare;
  6. richiede all’utente gli estremi del range di prezzo e stampa a schermo tutte le case che rientrano in tale range;
  7. gestisce le eccezioni che possono essere sollevate;
  8. richiama tutte le funzioni viste (main).

NOTA: l’eventuale ridondanza di codici identificativi delle case verrà penalizzata nel punteggio.

Codice Python

  1. class Casa:
  2.  
  3.     def __init__(self, prezzo, n_vani=1, mq = 50, ascensore = "si", condominio = "si", garage = "si"):
  4.         self.__prezzo = prezzo
  5.         self.__n_vani = n_vani
  6.         self.__mq = mq
  7.         self.__ascensore = ascensore
  8.         self.__condominio = condominio
  9.         self.__garage = garage
  10.  
  11.  
  12.     def set_prezzo(self, prezzo):
  13.         self.__prezzo=prezzo
  14.  
  15.     def set_n_vani(self,n_vani):
  16.         self.__n_vani=n_vani
  17.  
  18.     def set_mq(self, mq):
  19.         self.__mq= mq
  20.  
  21.     def set_ascensore(self, ascensore):
  22.         self.__ascensore= ascensore
  23.  
  24.     def set_condominio(self, condominio):
  25.         self.__condominio= condominio
  26.  
  27.     def set_garage(self, garage):
  28.         self.__garage= garage
  29.  
  30.     def get_prezzo(self):
  31.         return self.__prezzo
  32.  
  33.     def get_n_vani(self):
  34.         return self.__n_vani
  35.  
  36.     def get_mq(self):
  37.         return self.__mq
  38.  
  39.     def get_ascensore(self):
  40.         return self.__ascensore
  41.  
  42.     def get_condominio(self):
  43.         return self.__condominio
  44.  
  45.     def get_garage(self):
  46.         return self.__garage
  47.  
  48.     def __str__(self):
  49.         return "Prezzo: "+str(format(self.__prezzo,".2f"))+" €, N. vani: "+str(self.__n_vani)+", Metri quadri: "+str(self.__mq)+", Ascensore: "+self.__ascensore+\
  50.                ", Condominio: "+self.__condominio+", Garage: "+self.__garage

Di seguito la funzione main che mostra il funzionamento dei metodi definiti.

  1. from casa import Casa
  2. import pickle
  3.  
  4. ADD_HOUSE = 1
  5. DELETE_HOUSE = 2
  6. PRINT_HOUSES = 3
  7. SAVE = 4
  8. QUIT_CHOICE = 5
  9.  
  10.  
  11. def display_menu():
  12.     print()
  13.     print("MENU")
  14.     print("1) Inserire una nuova casa da gestire")
  15.     print("2) Eliminare una casa dall'elenco")
  16.     print("3) Stampare a schermo tutte le case in gestione")
  17.     print("4) Salvare le informazioni delle case in memoria")
  18.     print("5) Uscire dal programma")
  19.     print()
  20.  
  21. def ask_house_info():
  22.     try:
  23.         prezzo = float(input("Inserire il prezzo della casa: "))
  24.         n_vani = float(input("Inserire il numero dei vani della casa: "))
  25.         mq = float(input("Inserire i metri quadri della casa: "))
  26.         ascensore = input("La casa dispone di ascensore? ")
  27.         condominio = input("La casa e' inserita in un condominio? ")
  28.         garage = input("La casa dispone di un garage? ")
  29.         c = Casa(prezzo, n_vani, mq, ascensore, condominio, garage)
  30.         return c
  31.     except Exception as err:
  32.         print(err)
  33.         return 1
  34.  
  35. def main():
  36.     agenzia = dict()
  37.  
  38.     choice = 0
  39.     while choice != QUIT_CHOICE:
  40.         display_menu()
  41.  
  42.         choice = int(input('Inserire la scelta: '))
  43.  
  44.         if choice == ADD_HOUSE:
  45.             codice = input("Inserire il codice univoco della casa: ")
  46.             c = ask_house_info()
  47.             if c!=1:
  48.                 agenzia[codice] = c
  49.  
  50.         elif choice == DELETE_HOUSE:
  51.             codice = input("Inserire il codice univoco della casa da eliminare: ")
  52.             print()
  53.             if codice in agenzia:
  54.                 del agenzia[codice]
  55.                 print("La casa con "+codice+" e' stata eliminata")
  56.             else:
  57.                 print("Codice univoco della casa non corretto")
  58.             print()
  59.  
  60.         elif choice == PRINT_HOUSES:
  61.             print()
  62.             if len(agenzia)==0:
  63.                 print("Nessuna casa in gestione")
  64.             else:
  65.                 for key in agenzia:
  66.                     print("Codice: "+key+" - "+str(agenzia[key]))
  67.                     print()
  68.  
  69.         elif choice == SAVE:
  70.             namefile = input("Inserire il nome del file dove memorizzare i dati delle case: ")
  71.             file = open(namefile,'wb')
  72.             pickle.dump(agenzia, file)
  73.             file.close()
  74.  
  75.         elif choice!= QUIT_CHOICE:
  76.             print('Errore: scelta non valida')
  77.  
  78.  
  79. main()


Appello 08 Novembre 2017

Esercizio 2: Si ha la necessità di definire quattro classi in Python: Mammifero, Felino, Canidi, Gatto. Le classi elencate sono in relazioni diverse tra loro. Scrivere il codice Python che permette di definire le quattro classi su elencate (tenendo conto del concetto di ereditarietà) e un piccolo main che ne richiama i metodi definiti.

NOTA IMPORTANTE: si definiscano solo: gli attributi (almeno due per ogni sottoclasse); i metodi init, get, set e str per ogni classe.

Codice Python Di seguito il codice python che modella l'ereditarietà tra le classi.

  1. class Mammifero:
  2.     def __init__(self, eta, alimentazione):
  3.         self.__eta = eta
  4.         self.__alimentazione = alimentazione
  5.  
  6.     def get_eta(self):
  7.         return self.__eta
  8.  
  9.     def set_eta(self, eta):
  10.         self.__eta = eta
  11.  
  12.     def get_alimentazione(self):
  13.         return self.__alimentazione
  14.  
  15.     def set_alimentazione(self, alimentazione):
  16.         self.__alimentazione = alimentazione
  17.  
  18.     def __str__(self):
  19.         return "Etá: "+str(self.__eta)+", Alimentazione: "+str(self.__alimentazione)
  20.  
  21. class Felino(Mammifero):
  22.     def __init__(self, eta, alimentazione, habitat, pelo):
  23.         Mammifero.__init__(self, eta, alimentazione)
  24.         self.__habitat = habitat
  25.         self.__pelo = pelo
  26.  
  27.     def get_habitat(self):
  28.         return self.__habitat
  29.  
  30.     def set_habitat(self, habitat):
  31.         self.__habitat = habitat
  32.  
  33.     def get_pelo(self):
  34.         return self.__pelo
  35.  
  36.     def set_pelo(self, pelo):
  37.         self.__pelo = pelo
  38.  
  39.     def __str__(self):
  40.         return Mammifero.__str__(self)+", Habitat: "+ str(self.__habitat)+", Pelo: "+ str(self.__pelo)
  41.  
  42. class Canide(Mammifero):
  43.     def __init__(self, eta, alimentazione, verso, origine):
  44.         Mammifero.__init__(self, eta, alimentazione)
  45.         self.__verso = verso
  46.         self.__origine = origine
  47.  
  48.     def get_verso(self):
  49.         return self.__verso
  50.  
  51.     def set_verso(self, verso):
  52.         self.__verso = verso
  53.  
  54.     def get_origine(self):
  55.         return self.__origine
  56.  
  57.     def set_origine(self, origine):
  58.         self.__origine = origine
  59.  
  60.     def __str__(self):
  61.         return Mammifero.__str__(self)+", Verso: "+ str(self.__verso)+" Origine: "+ str(self.__origine)
  62.  
  63. class Gatto(Felino):
  64.     def __init__(self, eta, alimentazione, habitat, pelo, razza, colore):
  65.         Felino.__init__(self, eta, alimentazione, habitat, pelo)
  66.         self.__razza = razza
  67.         self.__colore = colore
  68.  
  69.     def get_razza(self):
  70.         return self.__razza
  71.  
  72.     def set_razza(self, razza):
  73.         self.__razza = razza
  74.  
  75.     def get_colore(self):
  76.         return self.__colore
  77.  
  78.     def set_colore(self, colore):
  79.         self.__colore = colore
  80.  
  81.     def __str__(self):
  82.         return Felino.__str__(self)+", Razza: "+ self.__razza+", Colore: "+ self.__colore

Di seguito la funzione main che mostra il funzionamento dei metodi definiti.

  1. import ereditarieta
  2.  
  3. def main():
  4.     a = ereditarieta.Mammifero(15, "Vegetariano")
  5.     b = ereditarieta.Felino(13, "Carnivoro", "Savana", "Lungo")
  6.     c = ereditarieta.Gatto(4, "Carnivoro", "Domestico", "Corto", "Siamese", "Bianco")
  7.     d = ereditarieta.Canide(1, "Onnivoro", "Abbaiare", "Germania") 
  8.  
  9.     print(a)
  10.     print(b)
  11.     print(c)
  12.     print(d)
  13.     print(c.get_colore())
  14.     print(c.get_habitat())
  15.     d.set_origine("Italia")
  16.     print(d)
  17.  
  18. main()


Esercizio 3: Si ha la necessità di gestire un laboratorio per l’analisi del sangue. In particolare, ogni parametro ematico che può essere analizzato dal laboratorio ha un suo codice univoco alfanumerico e le seguenti 5 informazioni: nome parametro, minimo (valore numerico), massimo (valore numerico), unità di misura, descrizione. Tali dati sono organizzati in un dizionario per cui:

  • la chiave corrisponde al codice univoco alfanumerico del parametro ematico;
  • il “valore” corrisponde alle informazioni del parametro ematico organizzate in una classe.

Tale dizionario è memorizzato in un file binario. La tipica richiesta rivolta all’operatore del laboratorio, a seguito dell’analisi del sangue di una persona, è quella di inserire manualmente i codici alfanumerici dei parametri ematici della persona e i corrispondenti valori risultanti dall’analisi. Si richiede sia di rappresentare uno schema grafico (non formale) delle strutture dati utilizzate sia di scrivere il codice Python dell’algoritmo che:

  1. definisce un oggetto parametro ematico con le informazioni ad essa relative;
  2. inizializza il dizionario leggendo da file binario;
  3. stampa a schermo tutti i valori di riferimento contenuti nel dizionario;
  4. permette all’operatore di interrogare N (a scelta dello stesso operatore) volte il sistema inserendo N volte i codici alfanumerici dei parametri ematici della persona e i corrispondenti valori risultanti dall’analisi. In particolare, per ciascuna interrogazione:
    • dopo che l’operatore avrà inserito il codice alfanumerico corrispondente ad un parametro ematico, dovranno essere stampate a schermo tutte le informazioni relative a tale parametro ematico;
    • dopo la stampa di tutte le informazioni, l’operatore dovrà poter inserire il valore del parametro ematico e ricevere un messaggio per sapere se il valore è nel range o fuori range;
  5. gestisce le eccezioni che possono essere sollevate;
  6. richiama tutte le funzioni viste (main).

NOTA: l’eventuale ridondanza di codici identificativi delle case verrà penalizzata nel punteggio.

Codice Python

  1. class PE:
  2.  
  3.     def __init__(self, nome, minimo, massimo, u_misura, descrizione):
  4.         self.__nome = nome
  5.         self.__minimo = minimo
  6.         self.__massimo = massimo
  7.         self.__u_misura = u_misura
  8.         self.__descrizione = descrizione
  9.  
  10.  
  11.     def set_nome(self, nome):
  12.         self.__nome=nome
  13.  
  14.     def set_minimo(self,minimo):
  15.         self.__minimo=minimo
  16.  
  17.     def set_massimo(self, massimo):
  18.         self.__massimo= massimo
  19.  
  20.     def set_u_misura(self, u_misura):
  21.         self.__u_misura= u_misura
  22.  
  23.     def set_descrizione(self, descrizione):
  24.         self.__descrizione= descrizione
  25.  
  26.     def get_nome(self):
  27.         return self.__nome
  28.  
  29.     def get_minimo(self):
  30.         return self.__minimo
  31.  
  32.     def get_massimo(self):
  33.         return self.__massimo
  34.  
  35.     def get_u_misura(self):
  36.         return self.__u_misura
  37.  
  38.     def get_descrizione(self):
  39.         return self.__descrizione
  40.  
  41.     def __str__(self):
  42.         return "Parametro ematico\nNome: "+self.__nome+" - Range = minimo: "+str(format(self.__minimo,".2f"))+"- massimo: "+str(format(self.__massimo,".2f"))+", u_misura: "+self.__u_misura+\
  43.                ", descrizione: "+self.__descrizione

Di seguito la funzione main che mostra il funzionamento dei metodi definiti. Si allega il file necessario per l'esecuzione del codice di esempio: Parametri.dat

  1. import pickle
  2. import parametro_ematico    
  3.  
  4. def main():
  5.     try:
  6.         #namefile = input("Inserire il nome del file dove sono memorizzati i dati dei parametri ematici: ")
  7.         input_file = open('Parametri.dat','rb')
  8.         analisi = pickle.load(input_file)
  9.  
  10.         print()
  11.  
  12.         for key in analisi:
  13.             print("Codice parametro ematico: "+key+"\n"+str(analisi[key]))
  14.  
  15.  
  16.         N = int(input("\nInserire il numero di interrogazioni per i parametri ematici: "))
  17.  
  18.         for i in range(1,N+1):
  19.             codice = input("\nInserire il codice univoco del parametro ematico: ")
  20.             print("\nCodice parametro ematico: "+codice+"\n"+str(analisi[codice]))
  21.             value = float(input("Inserire valore del parametro ematico derivante dall'analisi: "))
  22.             if (value>=float(analisi[codice].get_minimo())) and (value<=float(analisi[codice].get_massimo())):
  23.                 print("Valore del parametro "+analisi[codice].get_nome()+" nella norma")
  24.             else:
  25.                 print("Valore del parametro "+analisi[codice].get_nome()+" FUORI NORMA")
  26.             print()
  27.  
  28.     except Exception as err:
  29.         print(err)
  30.         return(1)
  31.  
  32. main()


Appello 17 Gennaio 2018

Esercizio 2: Si ha la necessità di definire quattro classi in Python: Forma geometrica, Poligono, Quadrato, Ellisse. Le classi elencate sono in relazioni diverse tra loro. Scrivere il codice Python che permette di definire le quattro classi su elencate (tenendo conto del concetto di ereditarietà) e un piccolo main che ne richiama i metodi definiti.

NOTA IMPORTANTE: si definiscano solo: gli attributi (almeno uno per ogni sottoclasse); i metodi init, get, set e str per ogni classe.

Codice Python Di seguito il codice python che modella l'ereditarietà tra le classi.

  1. class Forma:
  2.     def __init__(self, colore):
  3.         self.__colore = colore
  4.  
  5.     def get_colore(self):
  6.         return self.__colore
  7.  
  8.     def set_colore(self, colore):
  9.         self.__colore = colore
  10.  
  11.     def __str__(self):
  12.         return "Colore: "+self.__colore
  13.  
  14. class Poligono(Forma):
  15.     def __init__(self, colore, nlati):
  16.         Forma.__init__(self, colore)
  17.         self.__nlati = nlati
  18.  
  19.     def get_nlati(self):
  20.         return self.__nlati
  21.  
  22.     def set_nlati(self, nlati):
  23.         self.__nlati = nlati
  24.  
  25.     def __str__(self):
  26.         return Forma.__str__(self)+", n. lati: "+ str(self.__nlati)
  27.  
  28. class Ellisse(Forma):
  29.     def __init__(self, colore, asse_maggiore):
  30.         Forma.__init__(self, colore)
  31.         self.__asse_maggiore = asse_maggiore
  32.  
  33.     def get_asse_maggiore(self):
  34.         return self.__asse_maggiore
  35.  
  36.     def set_asse_maggiore(self, asse_maggiore):
  37.         self.__asse_maggiore = asse_maggiore
  38.  
  39.     def __str__(self):
  40.         return Forma.__str__(self)+" asse_maggiore: "+ str(self.__asse_maggiore)
  41.  
  42. class Quadrato(Poligono):
  43.     def __init__(self, colore, nlati, dim):
  44.         Poligono.__init__(self, colore, nlati)
  45.         self.__dim = dim
  46.  
  47.     def get_dim(self):
  48.         return self.__dim
  49.  
  50.     def set_dim(self, dim):
  51.         self.__dim = dim
  52.  
  53.     def __str__(self):
  54.         return Poligono.__str__(self)+", dim: "+ str(self.__dim)

Di seguito la funzione main che mostra il funzionamento dei metodi definiti.

  1. import ereditarieta
  2.  
  3. def main():
  4.     a = ereditarieta.Forma("Giallo")
  5.     b = ereditarieta.Poligono("Verde", 6)
  6.     c = ereditarieta.Ellisse("Blu", 34.5)
  7.     d = ereditarieta.Quadrato("Bianco",4,4.3) 
  8.  
  9.     print(a)
  10.     print(b)
  11.     print(c)
  12.     print(d)
  13.     print(c.get_asse_maggiore())
  14.     d.set_dim(6.4)
  15.     print(d)
  16.  
  17. main()


Esercizio 3: Si ha la necessità di gestire un magazzino di prodotti. In particolare, ogni prodotto del magazzino ha un suo codice univoco alfanumerico e le seguenti 5 informazioni: nome prodotto, altezza in cm (valore numerico), larghezza in cm (valore numerico), profondità in cm (valore numerico), prezzo. Tali dati sono organizzati in un dizionario per cui:

  • la chiave corrisponde al codice univoco alfanumerico del prodotto;
  • il “valore” corrisponde alle informazioni del prodotto organizzate in una classe.

La tipica richiesta rivolta all’operatore del magazzino di prodotti, è quella di ricercare tutti i prodotti il cui prezzo risulti essere compreso in un intervallo definito dall’operatore stesso. Si richiede sia di rappresentare uno schema grafico (non formale) delle strutture dati utilizzate sia di scrivere il codice Python dell’algoritmo che:

  1. definisce un oggetto prodotto con le informazioni ad essa relative;
  2. inizializza il dizionario con dati inventati;
  3. stampa a schermo tutti i prodotti contenuti nel magazzino;
  4. permette all’operatore di inserire il valore minimo e massimo dell’intervallo di prezzo per la ricerca dei prodotti. A seguito della definizione dell’intervallo, stampa a schermo il sottoinsieme di prodotti contenuti nel magazzino il cui prezzo ricade nell’intervallo stesso;
  5. scrive in memoria il dizionario in un file binario;
  6. gestisce le eccezioni che possono essere sollevate;
  7. richiama tutte le funzioni viste (main).

NOTA: l’eventuale ridondanza di codici identificativi delle case verrà penalizzata nel punteggio.

Codice Python

  1. class Prodotto:
  2.  
  3.     def __init__(self, nome, altezza, larghezza, profondita, prezzo):
  4.         self.__nome = nome
  5.         self.__altezza = altezza
  6.         self.__larghezza = larghezza
  7.         self.__profondita = profondita
  8.         self.__prezzo = prezzo
  9.  
  10.     def set_nome(self, nome):
  11.         self.__nome=nome
  12.  
  13.     def set_altezza(self,altezza):
  14.         self.__altezza=altezza
  15.  
  16.     def set_larghezza(self, larghezza):
  17.         self.__larghezza= larghezza
  18.  
  19.     def set_profondita(self, profondita):
  20.         self.__profondita= profondita
  21.  
  22.     def set_prezzo(self, prezzo):
  23.         self.__prezzo= prezzo
  24.  
  25.     def get_nome(self):
  26.         return self.__nome
  27.  
  28.     def get_altezza(self):
  29.         return self.__altezza
  30.  
  31.     def get_larghezza(self):
  32.         return self.__larghezza
  33.  
  34.     def get_profondita(self):
  35.         return self.__profondita
  36.  
  37.     def get_prezzo(self):
  38.         return self.__prezzo
  39.  
  40.     def __str__(self):
  41.         return "Prodotto\nNome: "+self.__nome+" - Altezza: "+str(format(self.__altezza,".2f"))+"- larghezza: "+str(format(self.__larghezza,".2f"))+", profondita: "+str(format(self.__profondita,".2f"))+\
  42.                ", prezzo: "+str(format(self.__prezzo,".2f")) + " euro"

Di seguito la funzione main che mostra il funzionamento dei metodi definiti.

  1. import pickle
  2. import prodotto
  3.  
  4. def print_magazzino(m):
  5. 	for key in m:
  6. 		print("Codice prodotto: "+key+"\t"+str(m[key]))
  7.  
  8. def save_magazzino(m):
  9. 	namefile = input("Inserire il nome del file dove salvare il magazzino prodotti: ")
  10. 	output_file = open(namefile,'wb')
  11. 	pickle.dump(m, output_file)
  12. 	output_file.close()
  13.  
  14. def inserisci_prodotto():
  15. 	nome = input("\nInserire il nome del prodotto: ")
  16. 	altezza = float(input("Inserire l'altezza del prodotto: "))
  17. 	larghezza = float(input("Inserire la larghezza del prodotto: "))
  18. 	profondita = float(input("Inserire la profondita' del prodotto: "))
  19. 	prezzo = float(input("Inserire il prezzo del prodotto: "))
  20. 	p = prodotto.Prodotto(nome,altezza,larghezza,profondita,prezzo)
  21. 	return p
  22.  
  23. def main():
  24. 	m=dict()
  25. 	try:
  26. 		N = int(input("\nInserire il numero di prodotti per il magazzino: "))
  27. 		for i in range(N):
  28. 			codice = input("Inserire il codice del prodotto: ")
  29. 			m[codice] = inserisci_prodotto()
  30.  
  31. 		print_magazzino(m)
  32. 		save_magazzino(m)
  33.  
  34. 		N = int(input("\nInserire il numero di ricerche di prodotti per prezzo che intendi effettuare: "))
  35. 		for i in range(N):
  36. 			ei = float(input("Inserire l'estremo inferiore dell'intervallo di prezzo: "))
  37. 			es = float(input("Inserire l'estremo superiore dell'intervallo di prezzo: "))
  38. 			for codice in m:
  39. 				if (float(m[codice].get_prezzo())>=ei) and (float(m[codice].get_prezzo())<=es):
  40. 					print("Prodotto "+codice+" - "+str(m[codice]))
  41. 	except Exception as err:
  42. 		print(err)
  43. 		return(1)
  44.  
  45. main()


Appello 14 Febbraio 2018

Esercizio 2: Si ha la necessità di definire quattro classi in Python: veicolo, auto, auto elettrica e moto. Le classi elencate sono in relazioni diverse tra loro. Scrivere il codice Python che permette di definire le tre classi su elencate (tenendo conto del concetto di ereditarietà) e un piccolo main che ne richiama i metodi definiti.

NOTA IMPORTANTE: si definiscano solo: gli attributi (almeno uno per ogni sottoclasse); i metodi init, get, set e str per ogni classe.

Codice Python Di seguito il codice python che modella l'ereditarietà tra le classi.

  1. class Veicolo:
  2.     def __init__(self, tipo):
  3.         self.__tipo = tipo
  4.  
  5.     def get_tipo(self):
  6.         return self.__tipo
  7.  
  8.     def set_tipo(self, tipo):
  9.         self.__tipo = tipo
  10.  
  11.     def __str__(self):
  12.         return "Tipo: " + self.__tipo
  13.  
  14.  
  15. class Auto(Veicolo):
  16.     def __init__(self, tipo, anno):
  17.         Veicolo.__init__(self, tipo)
  18.         self.__anno = anno
  19.  
  20.     def get_anno(self):
  21.         return self.__anno
  22.  
  23.     def set_anno(self, anno):
  24.         self.__anno = anno
  25.  
  26.     def __str__(self):
  27.         return Veicolo.__str__(self)+", Anno: " + str(self.__anno)
  28.  
  29.  
  30. class AutoElettrica(Auto):
  31.     def __init__(self, tipo, anno, autonomia):
  32.         Auto.__init__(self, tipo, anno)
  33.         self.__autonomia = autonomia
  34.  
  35.     def get_autonomia(self):
  36.         return self.__durata
  37.  
  38.     def set_autonomia(self, autonomia):
  39.         self.__autonomia = autonomia
  40.  
  41.     def __str__(self):
  42.         return Auto.__str__(self)+", Autonomia: "+ str(self.__autonomia) + " km"
  43.  
  44. class Moto(Veicolo):
  45.     def __init__(self, tipo, modello):
  46.         Veicolo.__init__(self, tipo)
  47.         self.__modello = modello
  48.  
  49.     def get_modello(self):
  50.         return self.__modello
  51.  
  52.     def set_modello(self, modello):
  53.         self.__modello = modello
  54.  
  55.     def __str__(self):
  56.         return Veicolo.__str__(self) + ", Modello: " + self.__modello

Di seguito la funzione main che mostra il funzionamento dei metodi definiti.

  1. import ereditarieta
  2.  
  3. def main():
  4.     v = ereditarieta.Veicolo("anfibio")
  5.     a = ereditarieta.Auto("terrestre", 2005)
  6.     ae = ereditarieta.AutoElettrica("terrestre", 2010, 300)
  7.     m = ereditarieta.Moto("terrestre", "Ducati")
  8.  
  9.     print(v)
  10.     print(a)
  11.     print(ae)
  12.     print(m)
  13.     print(a.get_anno())
  14.     ae.set_autonomia(400)
  15.     print(ae)
  16.  
  17. main()


Esercizio 3: Si ha la necessità di gestire una biblioteca. In particolare, ogni articolo presente in biblioteca (libro, rivista, ecc.) ha un suo codice univoco alfanumerico e le seguenti 5 informazioni: titolo, autore/i (uno o più organizzati in una lista), anno di pubblicazione (valore numerico), tipo (stringa – es. libro, rivista, ecc.) e numero ristampe (valore numerico). Tali dati sono organizzati in un dizionario per cui:

  • la chiave corrisponde al codice univoco alfanumerico del prodotto;
  • il “valore” corrisponde alle informazioni del prodotto organizzate in una classe.

Le tipiche richieste svolte da un addetto sono l’inserimento di un nuovo articolo e la ricerca in base al tipo. Si richiede sia di rappresentare uno schema grafio (non formale) delle strutture dati utilizzate sia di scrivere il codice Python dell’algoritmo che tramite un menù:

  1. permette di inserire un nuovo articolo e le relative informazioni;
  2. permette di eliminare un articolo esistente;
  3. stampa a schermo tutti gli articoli presenti;
  4. salva su un file binario tutti gli articoli presenti;
  5. permette di chiedere all’utente il tipo di articolo da ricercare e stampi a schermo tutti gli articoli corrispondenti;
  6. gestisce le eccezioni che possono essere sollevate;
  7. richiama tutte le funzioni viste (main).

NOTA: l’eventuale ridondanza di codici identificativi delle case verrà penalizzata nel punteggio.

Codice Python

  1. class Articolo:
  2.  
  3.     def __init__(self, titolo, autori, anno, tipo, ristampe):
  4.         self.__titolo = titolo
  5.         self.__autori = autori
  6.         self.__anno = anno
  7.         self.__tipo = tipo
  8.         self.__ristampe = ristampe
  9.  
  10.     def set_titolo(self, titolo):
  11.         self.__titolo = titolo
  12.  
  13.     def set_autori(self, autori):
  14.         self.__autori = autori
  15.  
  16.     def set_anno(self, anno):
  17.         self.__anno = anno
  18.  
  19.     def set_tipo(self, tipo):
  20.         self.__tipo = tipo
  21.  
  22.     def set_ristampe(self, ristampe):
  23.         self.__ristampe = ristampe
  24.  
  25.     def get_titolo(self):
  26.         return self.__titolo
  27.  
  28.     def get_autori(self):
  29.         return self.__autori
  30.  
  31.     def get_anno(self):
  32.         return self.__anno
  33.  
  34.     def get_tipo(self):
  35.         return self.__tipo
  36.  
  37.     def get_ristampe(self):
  38.         return self.__ristampe
  39.  
  40.     def __str__(self):
  41.  
  42.         lista_autori = self.__autori[0] + ", "
  43.         for i in range(1,len(self.__autori)):
  44.             lista_autori = lista_autori + self.__autori[i] + ", "
  45.  
  46.         return "Titolo: " + self.__titolo +\
  47.                ", Autori: " + lista_autori +\
  48.                "Anno: " + str(self.__anno) +\
  49.                ", Tipo: " + self.__tipo +\
  50.                ", N. Ristampe: " + str(self.__ristampe)

Di seguito la funzione main che mostra il funzionamento dei metodi definiti.

  1. from articolo import Articolo
  2. import pickle
  3.  
  4. ADD_ITEM = 1
  5. DELETE_ITEM = 2
  6. PRINT_ITEMS = 3
  7. SAVE = 4
  8. SEARCH = 5
  9. QUIT_CHOICE = 6
  10.  
  11.  
  12. def display_menu():
  13.     print()
  14.     print("MENU")
  15.     print("1) Inserire un nuovo articolo")
  16.     print("2) Eliminare un articolo dal catalogo")
  17.     print("3) Stampare a schermo tutti gli articoli in catalogo")
  18.     print("4) Salvare le informazioni degli articoli in memoria")
  19.     print("5) Cerca articoli per tipo")
  20.     print("6) Uscire dal programma")
  21.     print()
  22.  
  23. def ask_item_info():
  24.     try:
  25.         titolo = input("Inserire il titolo dell'articolo: ")
  26.  
  27.         autori = []
  28.         res = "s"
  29.         while res == "s" or res == "S":
  30.             autori.append(input("Inserire autore: "))
  31.             res = input("Vuoi inserire un ulteriore autore? [S/s = Si, N/n = No] ")
  32.  
  33.         anno = int(input("Inserire l'anno di pubblicazione: "))
  34.         tipo = input("Inserire il tipo (es. libro, rivista, ecc.): ")
  35.         ristampe = int(input("Inserire il numero di rispampe: "))
  36.  
  37.         c = Articolo(titolo, autori, anno, tipo, ristampe)
  38.         return c
  39.     except Exception as err:
  40.         print(err)
  41.         return 1
  42.  
  43. def main():
  44.     biblioteca = dict()
  45.  
  46.     choice = 0
  47.     while choice != QUIT_CHOICE:
  48.         display_menu()
  49.  
  50.         choice = int(input('Inserire la scelta: '))
  51.  
  52.         if choice == ADD_ITEM:
  53.             codice = input("Inserire il codice univoco dell' articolo: ")
  54.             if codice not in biblioteca:
  55.                 c = ask_item_info()
  56.                 if c!=1:
  57.                     biblioteca[codice] = c
  58.             else:
  59.                 print("Esiste gia' un articolo con questo codice univoco.")
  60.  
  61.         elif choice == DELETE_ITEM:
  62.             codice = input("Inserire il codice univoco dell'articolo da eliminare: ")
  63.             print()
  64.             if codice in biblioteca:
  65.                 del biblioteca[codice]
  66.                 print("L'articolo con codice "+codice+" e' stato eliminato.")
  67.             else:
  68.                 print("Articolo non trovato.")
  69.             print()
  70.  
  71.         elif choice == PRINT_ITEMS:
  72.             print()
  73.             if len(biblioteca)==0:
  74.                 print("Nessuna articolo presente")
  75.             else:
  76.                 for key in biblioteca:
  77.                     print("Codice: "+key+" - "+str(biblioteca[key]))
  78.                     print()
  79.  
  80.         elif choice == SAVE:
  81.             namefile = input("Inserire il nome del file dove memorizzare i dati degli articoli: ")
  82.             file = open(namefile,'wb')
  83.             pickle.dump(biblioteca, file)
  84.             file.close()
  85.  
  86.         elif choice == SEARCH:
  87.             tipo = input("Inserire il tipo di articoli richiesti: ")
  88.             empty = True
  89.             for key in biblioteca:
  90.                 if biblioteca[key].get_tipo() == tipo:
  91.                     print("Articolo " + key + ": " + str(biblioteca[key]))
  92.                     empty = False
  93.             if empty:
  94.                 print("Nessun articolo trovato.")
  95.  
  96.         elif choice!= QUIT_CHOICE:
  97.             print('Errore: scelta non valida')
  98.  
  99.  
  100. main()


Appello 19 Aprile 2018

Esercizio 4: Si ha la necessità di gestire le persone afferenti ad un istituto scolastico. In particolare, è necessario gestire i docenti e gli studenti appartenenti all’istituto in due liste differenti (una per i docenti e una per gli studenti). Ogni persona è caratterizzata dalle seguenti voci: nome, cognome, sesso, indirizzo di residenza e codice fiscale CF (16 caratteri alfanumerici); il personale e gli studenti sono caratterizzati da informazioni AGGIUNTIVE quali:

  • materia insegnata, ore settimanali e matricola (4 cifre) per i docenti;
  • indirizzo di studio, anno di frequenza e matricola (8 cifre) per gli studenti.

Tutte le informazioni sono contenute in un file di testo con la seguente struttura:

Docente
Mario
Rossi
M
via Orabona 4
RSSMRA18D19A662R
Informatica
8
1234
Studente
Tizia
Caio
F
via Amendola 126
CAITZI18D59A662L
Informatica
1
87654321

Scrivere il codice Python dell’algoritmo che:

  1. definisce la classe persona;
  2. definisce in maniera opportuna le classi docente e studente (ereditarietà);
  3. legge il file di testo, carica il contenuto del file in oggetti di tipo docente o studente e li pone nelle liste corrispondenti;
  4. stampa a schermo le informazioni dei docenti che insegnano per più di N ore settimanali, con N chiesto all’utente;
  5. permette di cercare una persona in base al CF e stampa a schermo le relative informazioni;
  6. permette di eliminare un utente in base al suo CF;
  7. permette di salvare la lista di soli docenti o di soli studenti in un file binario;
  8. gestisce le eccezioni che possono essere sollevate;
  9. richiama mediante un menu le funzioni implementate (main).

NOTA: codice mal strutturano e il non utilizzo della programmazione OO verrà penalizzata nel punteggio.

Codice Python

Di seguito il codice Python che implementa la classe Persona.

  1. class Persona():
  2.     def __init__(self, nome, cognome, sesso, residenza, cf):
  3.         self.nome = nome
  4.         self.cognome = cognome
  5.         self.sesso = sesso
  6.         self.residenza = residenza
  7.         self.cf = cf
  8.  
  9.     def setNome(self, nome):
  10.         self.nome = nome
  11.  
  12.     def setCongome(self, cognome):
  13.         self.cognome = cognome
  14.  
  15.     def setSesso(self, sesso):
  16.         self.sesso = sesso
  17.  
  18.     def setResidenza(self, residenza):
  19.         self.residenza = residenza
  20.  
  21.     def setCF(self, cf):
  22.         self.cf = cf
  23.  
  24.     def getNome(self):
  25.         return self.nome
  26.  
  27.     def getCognome(self):
  28.         return self.cognome
  29.  
  30.     def getSesso(self):
  31.         return self.sesso
  32.  
  33.     def getResidenza(self):
  34.         return self.residenza
  35.  
  36.     def getCF(self):
  37.         return self.cf
  38.  
  39.     def __str__(self):
  40.         return "Nome: " + self.nome + "\nCognome: " + self.cognome + "\nSesso: " + self.sesso + \
  41.                "\nResidenza: " + self.residenza + "\nCF: " + self.cf + "\n"

Di seguito il codice Python che implementa la classe Personale.

  1. from persona import Persona
  2.  
  3. class Personale(Persona):
  4.     def __init__(self, nome, cognome, sesso, residenza, cf, materia, ore, matricola):
  5.         Persona.__init__(self, nome, cognome, sesso, residenza, cf)
  6.         self.materia = materia
  7.         self.ore = ore
  8.         self.matricola = matricola
  9.  
  10.     def setMateria(self, materia):
  11.         self.materia = materia
  12.  
  13.     def setOre(self, ore):
  14.         self.ore = ore
  15.  
  16.     def setMatricola(self, matricola):
  17.         self.matricola = matricola
  18.  
  19.     def getMateria(self):
  20.         return self.materia
  21.  
  22.     def getOre(self):
  23.         return self.ore
  24.  
  25.     def getMatricola(self):
  26.         return self.matricola
  27.  
  28.     def __str__(self):
  29.         return Persona.__str__(self) + "Materia: " + self.materia + "\nOre: " + str(self.ore) + "\nMatricola: " + \
  30.                str(self.matricola) + "\n"

Di seguito il codice Python che implementa la classe Studente.

  1. from persona import Persona
  2.  
  3. class Studente(Persona):
  4.     def __init__(self, nome, cognome, sesso, residenza, cf, indirizzo, anno, matricola):
  5.         Persona.__init__(self, nome, cognome, sesso, residenza, cf)
  6.         self.indirizzo = indirizzo
  7.         self.anno = anno
  8.         self.matricola = matricola
  9.  
  10.     def setIndirizzo(self, indirizzo):
  11.         self.indirizzo = indirizzo
  12.  
  13.     def setAnno(self, anno):
  14.         self.anno = anno
  15.  
  16.     def setMatricola(self, matricola):
  17.         self.matricola = matricola
  18.  
  19.     def getIndirizzo(self):
  20.         return self.indirizzo
  21.  
  22.     def getAnno(self):
  23.         return self.anno
  24.  
  25.     def getMatricola(self):
  26.         return self.matricola
  27.  
  28.     def __str__(self):
  29.         return Persona.__str__(self) + "Indirizzo: " + self.indirizzo + "\nAnno: " + str(self.anno) + "\nMatricola: " + \
  30.                str(self.matricola) + "\n"

Di seguito la funzione main.

  1. from personale import Personale
  2. from studente import Studente
  3.  
  4. import pickle
  5.  
  6. LOAD_FILE = 1
  7. PRINT_TEACHERS = 2
  8. LOOK_FOR_CF = 3
  9. REMOVE_USER = 4
  10. SAVE_LIST = 5
  11. QUIT = 6
  12.  
  13. NUMERO_INFORMAZIONI = 9
  14.  
  15.  
  16. def display_menu():
  17.     print()
  18.     print("MENU")
  19.     print("1) Carica file")
  20.     print("2) Stampa docenti con almeno N ore settimanali")
  21.     print("3) Cerca per CF")
  22.     print("4) Elimina utente")
  23.     print("5) Salva lista docenti o studenti")
  24.     print("6) Esci")
  25.     print()
  26.  
  27. def load_file():
  28.     try:
  29.         file_name = input("Inserisci il nome del file: ")
  30.         file = open(file_name, 'r')
  31.  
  32.         row = file.readline()
  33.  
  34.         docenti = []
  35.         studenti = []
  36.  
  37.         temp_info = []
  38.  
  39.         while (row != ""):
  40.             temp_info.append(row.rstrip('\n'))
  41.             if len(temp_info) == NUMERO_INFORMAZIONI:
  42.                 # Ho terminato di caricare le informazioni necessarie per creare l'oggetto
  43.                 if temp_info[0] == "Docente":
  44.                     p = Personale(temp_info[1],
  45.                                              temp_info[2],
  46.                                              temp_info[3],
  47.                                              temp_info[4],
  48.                                              temp_info[5],
  49.                                              temp_info[6],
  50.                                              int(temp_info[7]),
  51.                                              int(temp_info[8])
  52.                                              )
  53.                     docenti.append(p)
  54.                 else:
  55.                     s = Studente(temp_info[1],
  56.                                              temp_info[2],
  57.                                              temp_info[3],
  58.                                              temp_info[4],
  59.                                              temp_info[5],
  60.                                              temp_info[6],
  61.                                              int(temp_info[7]),
  62.                                              int(temp_info[8])
  63.                                              )
  64.                     studenti.append(s)
  65.                 temp_info = []
  66.             row = file.readline()
  67.  
  68.         return docenti, studenti
  69.  
  70.  
  71.     except IOError as err:
  72.         print(err)
  73.         print("Errore nella lettura del file.")
  74.         return 0, 0
  75.  
  76.  
  77. def print_docenti(docenti):
  78.     try:
  79.         n = int(input("Inserire il numero di ore settimanali: "))
  80.         if n < 0:
  81.             raise ValueError
  82.  
  83.         for d in docenti:
  84.             if d.getOre() > n:
  85.                 print(d)
  86.  
  87.     except ValueError:
  88.         print("Numero non valido.")
  89.  
  90.  
  91. def look_for_cf(lista, cf):
  92.     idx = 0
  93.     for l in lista:
  94.         if l.getCF() == cf:
  95.             return idx
  96.         idx += 1
  97.     return -1
  98.  
  99.  
  100. def remove_user(l, cf):
  101.     idx = look_for_cf(l,cf)
  102.     if idx != -1:
  103.         del l[idx]
  104.     return l
  105.  
  106.  
  107. def save_list(l):
  108.     file_name = input("Inserire il nome del file: ")
  109.     file = open(file_name, 'wb')
  110.     pickle.dump(l, file)
  111.  
  112.  
  113. def main():
  114.     choice = 0
  115.     docenti = []
  116.     studenti = []
  117.     while choice != QUIT:
  118.         try:
  119.             display_menu()
  120.             choice = int(input('Inserire la scelta: '))
  121.  
  122.             if choice == LOAD_FILE:
  123.                 docenti, studenti = load_file()
  124.  
  125.             elif choice == PRINT_TEACHERS:
  126.                 print_docenti(docenti)
  127.  
  128.             elif choice == LOOK_FOR_CF:
  129.                 cf = input("Inserisci il CF da cercare: ")
  130.                 if len(cf) == 16:
  131.                     idx = look_for_cf(docenti, cf)
  132.                     if idx != -1:
  133.                         print(docenti[idx])
  134.                     else:
  135.                         idx = look_for_cf(studenti, cf)
  136.                         if idx != -1:
  137.                             print(studenti[idx])
  138.                         else:
  139.                             print("CF non trovato.")
  140.                 else:
  141.                     print("CF non valido")
  142.  
  143.             elif choice == REMOVE_USER:
  144.                 cf = input("Inserisci il CF da eliminare: ")
  145.                 if len(cf) == 16:
  146.                     docenti = remove_user(docenti, cf)
  147.                     studenti = remove_user(studenti, cf)
  148.                 else:
  149.                     print("CF non valido")
  150.  
  151.             elif choice == SAVE_LIST:
  152.                 tipo = input("Vuoi salvare la lista studenti (s) o docenti (d)? ")
  153.                 while tipo != 's' and tipo != 'd':
  154.                     print("Scelta errata.")
  155.                     tipo = input("Vuoi salvare la lista studenti (s) o docenti (d)? ")
  156.                 if tipo == 'd':
  157.                     save_list(docenti)
  158.                 else:
  159.                     save_list(studenti)
  160.  
  161.             elif choice != QUIT:
  162.                 print('Errore: scelta non valida')
  163.  
  164.         except ValueError:
  165.             print('Errore: scelta non valida')
  166.  
  167. main()


Appello 20 Giugno 2018

Esercizio 4: Si supponga di dover realizzare un programma che permetta di realizzare alcune operazioni su semplici poligoni. Nello specifico i poligoni di interesse sono quadrato, rettangolo, e triangolo. Ogni poligono è caratterizzato da una lista di punti. Tali punti costituiscono i vertici del poligono stesso e sono elencati in senso orario. Le comuni operazioni richieste sono il calcolo del perimetro per ogni poligono e l’area per le forme rettangolo e quadrato.

Si modelli il problema secondo i paradigmi della programmazione orientata agli oggetti e si utilizzino strutture dati opportune.

Riportare uno schema non formale delle strutture dati utilizzate e scrivere quindi il codice Python dell’algoritmo che:

  1. definisce la classe punto;
  2. definisce in maniera opportuna le classi poligono, triangolo, quadrato e rettangolo;
  3. permette all’utente, mediante un menu, di:
    • creare una nuova figura in base alla scelta dell’utente;
    • modificare i punti di una figura precedentemente creata;
    • calcolare e stampare a video il valore del perimetro;
    • calcolare e stampare a video il valore dell’area (per le figure per cui è ammesso);
  4. gestisce le eccezioni che possono essere generate;

NOTA 1: scegliere la migliore struttura dati per memorizzare tutte le forme geometriche.

NOTA 2: codice mal strutturato e il non utilizzo della programmazione OO verranno penalizzati nel punteggio.


Codice Python

Di seguito il codice Python che implementa la classe Punto.

  1. from math import sqrt
  2.  
  3. class Punto:
  4.     def __init__(self,x,y):
  5.         self.__x = x
  6.         self.__y = y
  7.  
  8.     def set_x(self,x):
  9.         self.__x = x
  10.  
  11.     def set_y(self,y):
  12.         self.__y = y
  13.  
  14.     def get_x(self):
  15.         return self.__x
  16.  
  17.     def get_y(self):
  18.         return self.__y
  19.  
  20.     def __str__(self):
  21.         return "X: " + str(self.__x) + ", Y: " + str(self.__y) + "\n"
  22.  
  23.     def distanza(self, p):
  24.         d_x = p.get_x() - self.__x
  25.         d_y = p.get_y() - self.__y
  26.  
  27.         return sqrt(d_x**2 + d_y**2)

Di seguito il codice Python che implementa le classi Poligono, Triangolo, Quadrato e Rettangolo.

  1. class Poligono:
  2.     def __init__(self, vertici):
  3.         self.__vertici = vertici
  4.  
  5.     def set_vertici(self,vertici):
  6.         self.__vertici = vertici
  7.  
  8.     def get_vertici(self):
  9.         return self.__vertici
  10.  
  11.     def __str__(self):
  12.         out = "Vertici:\n"
  13.         for v in self.__vertici:
  14.             out += str(v)
  15.         return out
  16.  
  17.     def perimetro(self):
  18.         per = 0
  19.         for i in range(0, len(self.__vertici)-1):
  20.             p1 = self.__vertici[i]
  21.             p2 = self.__vertici[i+1]
  22.             per += p1.distanza(p2)
  23.         per += self.__vertici[0].distanza(self.__vertici[-1])
  24.         return per
  25.         #raise NotImplementedError
  26.  
  27.     def area(self):
  28.         print("Metodo non implementato")    # O in alternative: raise NotImplementedError
  29.         return 0
  30.  
  31.  
  32. class Triangolo(Poligono):
  33.     def __init__(self,a,b,c):
  34.         Poligono.__init__(self, [a, b, c])
  35.  
  36.  
  37. class Rettangolo(Poligono):
  38.     def __init__(self,a,b,c,d):
  39.         Poligono.__init__(self, [a, b, c, d])
  40.  
  41.     def area(self):
  42.         v = Poligono.get_vertici(self)
  43.         l1 = v[0].distanza(v[1])
  44.         l2 = v[1].distanza(v[2])
  45.         return l1*l2
  46.  
  47.  
  48. class Quadrato(Rettangolo):
  49.     def __init__(self,a,b,c,d):
  50.         Rettangolo.__init__(self, a, b, c, d)


Di seguito la funzione main.

  1. from punto import Punto
  2. from forme_geometriche import Triangolo
  3. from forme_geometriche import Rettangolo
  4. from forme_geometriche import Quadrato
  5.  
  6. CREA = 1
  7. MODIFICA = 2
  8. PERIMETRO = 3
  9. AREA = 4
  10. ESCI = 5
  11.  
  12. def menu():
  13.     print("Inserisci la scelta:")
  14.     print("1) Crea")
  15.     print("2) Modifica")
  16.     print("3) Perimetro")
  17.     print("4) Area")
  18.     print("5) Esci")
  19.  
  20.     try:
  21.         return int(input())
  22.     except ValueError:
  23.         return 0
  24.  
  25.  
  26. def carica_lista_vertici(n):
  27.     v = []
  28.     for i in range(n):
  29.         try:
  30.             x = float(input("Vertice: " + str(i) + " - Inserisci X: "))
  31.             y = float(input("Vertice: " + str(i) + " - Inserisci Y: "))
  32.         except ValueError:
  33.             print("Valore non ammissibile")
  34.             return []
  35.         v.append(Punto(x,y))
  36.     return v
  37.  
  38.  
  39. def main():
  40.  
  41.     c = menu()
  42.     figura = None
  43.     while c != ESCI:
  44.         if c == CREA:
  45.             f = ''
  46.             while f != 't' and f != 'r' and f != 'q' and f != 'a':
  47.                 f = input("Inserire il tipo di figura (t = Triangolo, r = Rettangolo, q = Quadrato, a = Annulla): ")
  48.  
  49.             if f == 't':
  50.                  v = carica_lista_vertici(3)
  51.                  if len(v) > 0:
  52.                      figura = Triangolo(v[0],v[1],v[2])
  53.                      print("Figura creata")
  54.                  else:
  55.                     print("Figura non creata")
  56.             elif f == 'r':
  57.                 v = carica_lista_vertici(4)
  58.                 if len(v) > 0:
  59.                     figura = Rettangolo(v[0],v[1],v[2],v[3])
  60.                     print("Figura creata")
  61.                 else:
  62.                     print("Figura non creata")
  63.             elif f == 'q':
  64.                 v = carica_lista_vertici(4)
  65.                 if len(v) > 0:
  66.                     figura = Quadrato(v[0],v[1],v[2],v[3])
  67.                     print("Figura creata")
  68.                 else:
  69.                     print("Figura non creata")
  70.  
  71.         elif c == MODIFICA:
  72.             if figura:
  73.                 v = carica_lista_vertici(len(figura.get_vertici()))
  74.                 if len(v) > 0:
  75.                     figura.set_vertici(v)
  76.                     print("Figura modificata")
  77.                 else:
  78.                     print("Figura non modificata")
  79.             else:
  80.                 print("Creare prima la figura.")
  81.  
  82.         elif c == PERIMETRO:
  83.             if figura:
  84.                 print("Il perimetro è: ",format(figura.perimetro(),'.2f'))
  85.             else:
  86.                 print("Creare prima la figura.")
  87.         elif c == AREA:
  88.             if figura:
  89.                 print("L'area è: ",format(figura.area(),'.2f'))
  90.             else:
  91.                 print("Creare prima la figura.")
  92.         else:
  93.             print("Scelta errata.\n")
  94.  
  95.         c = menu()
  96.  
  97.  
  98. main()


Appello 18 Luglio 2018

Esercizio 4: Si ha la necessità di gestire l’inventario dei beni afferenti ad un ente pubblico. In particolare, ogni bene è caratterizzato dall’avere un numero di inventario univoco ad esso associato, l’anno di acquisto, un numero di fattura ed una descrizione. I beni, inoltre, sono suddivisi in due tipologie differenti: mobilio (armadi, schedari, scrivanie, ecc.) e supporti informatici (monitor, computer, stampanti, ecc.). Le singole tipologie sono a loro volta caratterizzate da:

  1. mobilio: luogo in cui è ubicato;
  2. supporti informatici: numero di serie (alfanumerico) e responsabile (nome e cognome) a cui è affidato.

Si modelli il problema secondo i paradigmi della programmazione orientata agli oggetti e si utilizzino strutture dati opportune. Riportare uno schema non formale delle strutture dati utilizzate e scrivere quindi il codice Python dell’algoritmo che:

  1. definisce la classe bene;
  2. definisce in maniera opportuna le classi mobilio e supporto informatico; c) permette all’utente, mediante un menu, di:
    • inserire un nuovo bene (che dovrà necessariamente appartenere ad una delle due tipologie precedenti: mobilio e supporto informatico);
    • cercare un bene mediante numero di inventario e stampare a schermo le relative informazioni;
    • cercare i beni acquistati in un dato anno e per ognuno di essi: stampare a schermo il numero di inventario e aggiungere al file “out.txt” il numero di fattura;
    • permette di salvare in binario i mobili e i supporti informatici in due file differenti;
  3. gestisce le eccezioni che possono essere generate.

NOTA 1: scegliere la migliore struttura dati per memorizzare tutti i beni tenendo conto delle informazioni disponibili su di essi.

NOTA 2: codice mal strutturato e il non utilizzo della programmazione OO verranno penalizzati nel punteggio. (max 23 punti)


Codice Python

Di seguito il codice Python che implementa la classe Bene.

  1. class Bene:
  2.     def __init__(self, anno, numero_fattura, descrizione):
  3.         self.__anno = anno
  4.         self.__numero_fattura = numero_fattura
  5.         self.__descrizione = descrizione
  6.  
  7.     def set_anno(self,anno):
  8.         self.__anno = anno
  9.  
  10.     def set_numero_fattura(self,numero_fattura):
  11.         self.__numero_fattura = numero_fattura
  12.  
  13.     def set_descrizione(self,descrizione):
  14.         self.__descrizione = descrizione
  15.  
  16.     def get_anno(self):
  17.         return self.__anno
  18.  
  19.     def get_numero_fattura(self):
  20.         return self.__numero_fattura
  21.  
  22.     def get_descrizione(self):
  23.         return self.__descrizione
  24.  
  25.     def __str__(self):
  26.         return "Anno: " + str(self.__anno) + ", Numero fattura: " + str(self.__numero_fattura) + ", Descrizione: " + self.__descrizione + "\n"

Di seguito il codice Python che implementa le classi Mobilio e Supporti Informatici.

  1. from bene import Bene
  2.  
  3.  
  4. class Mobilio(Bene):
  5.     def __init__(self, anno, numero_fattura, descrizione, luogo):
  6.         Bene.__init__(self, anno, numero_fattura, descrizione)
  7.         self.__luogo = luogo
  8.  
  9.     def set_luogo(self,luogo):
  10.         self.__luogo = luogo
  11.  
  12.     def get_luogo(self):
  13.         return self.__luogo
  14.  
  15.     def __str__(self):
  16.         return Bene.__str__(self) + "Luogo: " + self.__luogo + "\n"
  17.  
  18.  
  19. class SupportiInformatici(Bene):
  20.     def __init__(self, anno, numero_fattura, descrizione, serie, responsabile):
  21.         Bene.__init__(self, anno, numero_fattura, descrizione)
  22.         self.__serie = serie
  23.         self.__responsabile = responsabile
  24.  
  25.     def set_serie(self,serie):
  26.         self.__serie = serie
  27.  
  28.     def set_responsabile(self,responsabile):
  29.         self.__responsabile = responsabile
  30.  
  31.     def get_serie(self):
  32.         return self.__serie
  33.  
  34.     def get_responsabile(self):
  35.         return self.__responsabile
  36.  
  37.     def __str__(self):
  38.         return Bene.__str__(self) + "Numero di serie: " + self.__serie + ", Responsabile: " + self.__responsabile + "\n"

Di seguito la funzione main.

  1. from arredi import Mobilio
  2. from arredi import SupportiInformatici
  3. import pickle
  4.  
  5. INSERISCI = 1
  6. CERCA_PER_INVENTARIO = 2
  7. CERCA_PER_ANNO = 3
  8. SALVA = 4
  9. ESCI = 5
  10.  
  11. def menu():
  12.     print("Effettua la scelta:")
  13.     print("1) Inserisci bene")
  14.     print("2) Cerca per inventario")
  15.     print("3) Cerca per anno")
  16.     print("4) Salva")
  17.     print("5) Esci")
  18.  
  19.     try:
  20.         return int(input())
  21.     except ValueError:
  22.         return 0
  23.  
  24.  
  25. def carica_attributi_bene():
  26.     out = []
  27.     try:
  28.         out.append(int(input("Inserisci anno: ")))
  29.         out.append(int(input("Inserisci fattura: ")))
  30.     except ValueError:
  31.         print("Valore non valido.")
  32.         return []
  33.     out.append(input("Inserisci descrizione: "))
  34.     return out
  35.  
  36.  
  37. def main():
  38.     arredi = {}
  39.  
  40.     c = menu()
  41.     while c != ESCI:
  42.         if c == INSERISCI:
  43.             attr = carica_attributi_bene()
  44.             if len(attr) > 0:
  45.                 tipo = ''
  46.                 while tipo != 'm' and tipo != 'i' and tipo != 'a':
  47.                     tipo = input("Inserire il tipo di mobilio (m = Mobilio, i = Supporto Informatico, a = Annulla): ")
  48.  
  49.                 if tipo != 'a':
  50.  
  51.                     if tipo == 'm':
  52.                         attr.append(input("Inserire locazione: "))
  53.                     elif tipo == 'i':
  54.                         attr.append(input("Inserire numero di serie: "))
  55.                         attr.append(input("Inserire responsabile: "))
  56.  
  57.                     try:
  58.                         n_inv = int(input("Inserire il numero di inventario: "))
  59.                     except ValueError:
  60.                         print("Valore non valido.")
  61.                     else:
  62.                         if n_inv in arredi:
  63.                             print("Numero inventario esistente.")
  64.                         else:
  65.                             if tipo == 'm':
  66.                                 arredi[n_inv] = Mobilio(attr[0],attr[1],attr[2],attr[3])
  67.                             elif tipo == 'i':
  68.                                 arredi[n_inv] = SupportiInformatici(attr[0], attr[1], attr[2], attr[3], attr[4])
  69.  
  70.  
  71.         elif c == CERCA_PER_INVENTARIO:
  72.             try:
  73.                 n_inv = int(input("Inserire il numero di inventario da cercare: "))
  74.             except ValueError:
  75.                 print("Valore non valido.")
  76.             else:
  77.                 if n_inv in arredi:
  78.                     print(arredi[n_inv])
  79.                 else:
  80.                     print("Non presente in inventario.")
  81.  
  82.         elif c == CERCA_PER_ANNO:
  83.             try:
  84.                 anno = int(input("Inserire anno da cercare: "))
  85.             except ValueError:
  86.                 print("Valore non valido.")
  87.             else:
  88.                 file = open("out.txt","a")
  89.                 for n_inv in arredi:
  90.                     if arredi[n_inv].get_anno() == anno:
  91.                         print(n_inv)
  92.                         file.write(str(arredi[n_inv].get_numero_fattura()) + "\n")
  93.                 file.close()
  94.         elif c == SALVA:
  95.             file_mobilio = open("mobilio.dat", "bw")
  96.             file_supporti = open("supporti_informatici.dat", "bw")
  97.             for n_inv in arredi:
  98.                 if isinstance(arredi[n_inv],Mobilio):
  99.                     pickle.dump(arredi[n_inv],file_mobilio)
  100.                 else:
  101.                     pickle.dump(arredi[n_inv], file_supporti)
  102.             file_mobilio.close()
  103.             file_supporti.close()
  104.  
  105.         else:
  106.             print("Scelta non valida")
  107.  
  108.         c = menu()
  109.  
  110.  
  111. main()


Appello 03 Settembre 2018

Esercizio 4: Si ha la necessità di gestire il personale afferente ad un’azienda. In particolare, ogni persona è caratterizzata dall’avere un nome, un cognome e un numero di matricola univoco (8 numeri). Ci sono inoltre tre tipologie di dipendenti ognuno caratterizzato di diverse informazioni aggiuntive:

  1. operaio: reparto e salario;
  2. responsabile: reparto, salario e anno di promozione;
  3. dirigente: salario e anno di assunzione.

Tutte le informazioni sono salvate in un file di testo con la struttura riportata nel seguente esempio:


operaio
Mario
Rossi
12345678
produzione
1500
responsabile
Tizio
Caio
87654321
vendite
1800
2012
dirigente
Pinco
Pallino
01010101
3000
2018


Si modelli il problema secondo i paradigmi della programmazione orientata agli oggetti e scrivere quindi il codice Python dell’algoritmo che:

  1. definisce la classe persona;
  2. definisce in maniera opportuna le classi operaio, responsabile e dirigente;
  3. permette di:
    • caricare il file con le informazioni sui dipendenti all’interno di tre strutture dati opportune (una per ogni categoria di lavoro);
    • calcolare e stampare la somma degli stipendi per la categoria di lavoro scelta dall’utente;
    • chiedere all’utente l’anno di promozione del responsabile e stampare il numero di matricola del responsabile promosso nell’anno inserito che percepisce il salario maggiore;
    • salvare in un file binario le tre strutture dati create.
  4. gestisce le eccezioni che possono essere generate;
  5. richiama le funzioni implementate (main);

NOTA 1: codice mal strutturato e il non utilizzo della programmazione OO verranno penalizzati nel punteggio. (max 23 punti)


Codice Python

Di seguito il codice Python che implementa la classe Persona.

  1. class Persona:
  2.     def __init__(self,nome,cognome):
  3.         self.__nome = nome
  4.         self.__cognome = cognome
  5.  
  6.     def setNome(self,nome):
  7.         self.__nome = nome
  8.  
  9.     def setCognome(self,cognome):
  10.         self.__cognome = cognome
  11.  
  12.     def getNome(self):
  13.         return self.__nome
  14.  
  15.     def getCognome(self):
  16.         return self.__cognome
  17.  
  18.     def __str__(self):
  19.         return "Nome: " + self.__nome + "\nCognome: " + self.__cognome + "\n"

Di seguito il codice Python che implementa le classi Operaio, Responsabile e Dirigente.

  1. from persona import Persona
  2.  
  3. class Operaio(Persona):
  4.     def __init__(self,nome,cognome,reparto,salario):
  5.         Persona.__init__(self,nome,cognome)
  6.         self.__reparto = reparto
  7.         self.__salario = salario
  8.  
  9.     def setReparto(self,reparto):
  10.         self.__reparto = reparto
  11.  
  12.     def setSalario(self,salario):
  13.         self.__salario = salario
  14.  
  15.     def getReparto(self):
  16.         return self.__reparto
  17.  
  18.     def getSalario(self):
  19.         return self.__salario
  20.  
  21.     def __str__(self):
  22.         return Persona.__str__(self) + "Reparto: " + self.__reparto + "\nSalario: " + str(self.__salario) + "\n"
  23.  
  24. class Responsabile(Operaio):
  25.     def __init__(self,nome,cognome,reparto,salario,annop):
  26.         Operaio.__init__(self,nome,cognome,reparto,salario)
  27.         self.__annop = annop
  28.  
  29.     def setAnnoP(self,annop):
  30.         self.__annop = annop
  31.  
  32.     def getAnnoP(self):
  33.         return self.__annop
  34.  
  35.     def __str__(self):
  36.         return Operaio.__str__(self) + "\nAnno Promozione: " + str(self.__annop) + "\n"
  37.  
  38. class Dirigente(Persona):
  39.     def __init__(self,nome,cognome,salario,annoa):
  40.         Persona.__init__(self,nome,cognome)
  41.         self.__salario = salario
  42.         self.__annoa = annoa
  43.  
  44.     def setSalario(self,salario):
  45.         self.__salario = salario
  46.  
  47.     def setAnnoA(self,annoa):
  48.         self.__annoa = annoa
  49.  
  50.     def getSalario(self):
  51.         return self.__salario
  52.  
  53.     def fetAnnoA(self):
  54.         return self.__annoa
  55.  
  56.     def __str__(self):
  57.         return Persona.__str__(self) + "\nSalario: " + str(self.__salario) + "\nAnno Assunzione: " + str(self.__annoa) + "\n"

Di seguito la funzione main.

  1. from dipendenti import Operaio
  2. from dipendenti import Responsabile
  3. from dipendenti import Dirigente
  4.  
  5. import pickle
  6.  
  7. def load_file():
  8.     filename = input("Inserisci il nome del file: ")
  9.     file = open(filename,'r')
  10.  
  11.     operaio = {}
  12.     responsabile = {}
  13.     dirigente = {}
  14.  
  15.     # temp[0] nome
  16.     # temp[1] cognome
  17.     # temp[2] matricola
  18.     # temp[3] reparto
  19.     # temp[4] salario
  20.     # temp[5] anno
  21.  
  22.     tipo = file.readline().rstrip('\n')
  23.  
  24.     while tipo != '':
  25.         temp = []
  26.  
  27.         for i in range(5):
  28.             temp.append(file.readline().rstrip('\n'))
  29.  
  30.         if tipo == 'responsabile':
  31.             temp.append(file.readline().rstrip('\n'))
  32.             responsabile[temp[2]] = Responsabile(temp[0],
  33.                                                  temp[1],
  34.                                                  temp[3],
  35.                                                  temp[4],
  36.                                                  temp[5])
  37.         elif tipo == 'operaio':
  38.             operaio[temp[2]] = Operaio(temp[0],
  39.                                        temp[1],
  40.                                        temp[3],
  41.                                        temp[4])
  42.  
  43.         else:
  44.             dirigente[temp[2]] = Dirigente(temp[0],
  45.                                            temp[1],
  46.                                            temp[3],
  47.                                            temp[4])
  48.  
  49.         tipo = file.readline().rstrip('\n')
  50.  
  51.     file.close()
  52.     return operaio,responsabile,dirigente
  53.  
  54. def somma_per_categoria(d):
  55.     s = 0
  56.     for key in d:
  57.         s += float(d[key].getSalario())
  58.     print('Somma: ',s)
  59.  
  60. def cerca_responsabile(d):
  61.     best = 0.0
  62.     matricola = []
  63.     anno = int(input("Inserire anno di promozione: "))
  64.     for key in d:
  65.         if (int(d[key].getAnnoP()) == anno) & (float(d[key].getSalario()) >= best):
  66.             if float(d[key].getSalario()) == best: # Stesso salario
  67.                 matricola.append(key)
  68.             else:
  69.                 matricola = [key]
  70.                 best = float(d[key].getSalario())
  71.  
  72.     if len(matricola) > 0:
  73.         print('Matricola/e: ',*matricola)
  74.     else:
  75.         print('Nessun elemento soddisfa i criteri di ricerca.')
  76.  
  77. def salva(operaio, responsabile, dirigente):
  78.     filename = input('Inserire il nome del file in cui salvare: ')
  79.     file = open(filename,'bw')
  80.     pickle.dump(operaio, file)
  81.     pickle.dump(responsabile, file)
  82.     pickle.dump(dirigente, file)
  83.     file.close()
  84.  
  85. def main():
  86.     try:
  87.         operaio, responsabile, dirigente = load_file()
  88.  
  89.         categoria = ''
  90.         while categoria != 'a':
  91.             if categoria == 'o':
  92.                 somma_per_categoria(operaio)
  93.             elif categoria == 'r':
  94.                 somma_per_categoria(responsabile)
  95.             elif categoria == 'd':
  96.                 somma_per_categoria(dirigente)
  97.  
  98.             categoria = input('Inserire la categoria per cui calcolare la somma ("o" per Operaio, "r" per Responsabile, "d" per Dirigente o "a" per annullare): ')
  99.  
  100.         cerca_responsabile(responsabile)
  101.  
  102.         salva(operaio, responsabile, dirigente)
  103.  
  104.     except IOError:
  105.         print('Impossibile leggere il file.')
  106.     except ValueError:
  107.         print('Anno non valido')
  108.  
  109. main()


Appello 24 Settembre 2018

Esercizio 4: Si ha la necessità di gestire l’utenza di una compagnia telefonica. In particolare la compagnia ha la necessità di gestire gli utenti ad essa afferenti e i dispositivi usati dagli utenti stessi. Per quanto riguarda gli utenti le informazioni in possesso della compagnia sono: nome, cognome, età e codice fiscale. I dispositivi, invece, possono essere di due tipologie: telefono e smartphone. Le informazioni relative ad ogni telefono sono: produttore, modello e IMEI, mentre ogni smartphone possiede, oltre alle informazioni precedenti, caratteristiche aggiuntive, quali: dimensione dello schermo (lunghezza e larghezza) e anno di uscita. La compagnia ha la necessità di tenere traccia delle informazioni relative ad ogni utente ed in particolare i dispositivi (anche più di uno) in loro possesso. Si modelli il problema secondo i paradigmi della programmazione orientata agli oggetti e si scelga una opportuna struttura dati per memorizzare gli utenti, i dispositivi e per preservare l’associazione tra utente e dispositivi posseduti; si scriva quindi il codice Python dell’algoritmo che:

  1. definisce la classe utente;
  2. definisce in maniera opportuna le classi telefono e smartphone;
  3. permette di inserire un nuovo utente;
  4. permette di inserire un nuovo dispositivo e di associarlo ad un utente preesistente;
  5. permette di eliminare un utente e conseguentemente tutti i dispositivi ad esso associati;
  6. permette di cercare lo smartphone con schermo di area massima e stampare a schermo le relative informazioni;
  7. gestisce le eccezioni che possono essere generate;
  8. richiama le funzioni implementate mediante un menu.

NOTA 1: codice mal strutturato e il non utilizzo della programmazione OO verranno penalizzati nel punteggio.

Codice Python

Di seguito il codice Python che implementa la classe Utente.

  1. class Utente:
  2.     def __init__(self,nome,cognome,eta):
  3.         self.__nome = nome
  4.         self.__cognome = cognome
  5.         self.__eta = eta
  6.  
  7.     def setNome(self,nome):
  8.         self.__nome = nome
  9.  
  10.     def setCognome(self,cognome):
  11.         self.__cognome = cognome
  12.  
  13.     def setEta(self,eta):
  14.         self.__eta = eta
  15.  
  16.     def getNome(self):
  17.         return self.__nome
  18.  
  19.     def getCognome(self):
  20.         return self.__cognome
  21.  
  22.     def getEta(self):
  23.         return self.__eta
  24.  
  25.     def __str__(self):
  26.         return 'Nome: ' + self.__nome + '\nCognome: ' + self.__cognome + '\nEta\': ' + str(self.__eta) + '\n'

Di seguito il codice Python che implementa le classi Telefono e Smartphone.

  1. class Telefono:
  2.     def __init__(self,produttore,modello):
  3.         self.__produttore = produttore
  4.         self.__modello = modello
  5.  
  6.     def setProduttore(self,produttore):
  7.         self.__produttore = produttore
  8.  
  9.     def setModello(self,modello):
  10.         self.__modello = modello
  11.  
  12.     def getProduttore(self):
  13.         return self.__produttore
  14.  
  15.     def getModello(self):
  16.         return self.__modello
  17.  
  18.     def __str__(self):
  19.         return 'Produttore: ' + self.__produttore + '\nModello: ' + self.__modello + '\nIMEI: ' + '\n'
  20.  
  21.  
  22. class Smartphone(Telefono):
  23.     def __init__(self,produttore,modello,schermo,anno):
  24.         Telefono.__init__(self,produttore,modello)
  25.         self.__schermo = schermo
  26.         self.__anno = anno
  27.  
  28.     def setSchermo(self,lun,lar):
  29.         self.__schermo = [lun,lar]
  30.  
  31.     def setAnno(self,anno):
  32.         self.__anno = anno
  33.  
  34.     def getSchermo(self):
  35.         return self.__schermo
  36.  
  37.     def getAnno(self):
  38.         return self.__anno
  39.  
  40.     def __str__(self):
  41.         return Telefono.__str__(self) + 'Schermo: ' + str(self.__schermo[0]) + 'x' + str(self.__schermo[1]) + '\nAnno: ' + str(self.__anno) + '\n'

Di seguito la funzione main.

  1. from utente import Utente
  2. from dispositivi import Telefono, Smartphone
  3.  
  4. INSERISCI_UTENTE = 1
  5. INSERISCI_DISPOSITIVO = 2
  6. ELIMINA_UTENTE = 3
  7. CERCA_AREA = 4
  8. ESCI = 5
  9.  
  10. def menu():
  11.     print('Scelta:\n')
  12.     print('1) Inserisci Utente\n')
  13.     print('2) Inserisci Dispositivo\n')
  14.     print('3) Elimina Utente\n')
  15.     print('4) Cerca\n')
  16.     print('5) Esci\n\n')
  17.     try:
  18.         return int(input())
  19.     except ValueError:
  20.         return 0
  21.  
  22. def inserisci_utente(d,u_d,cf=None):
  23.     if not cf:
  24.         cf = input('CF: ')
  25.         if cf in d:
  26.             print('Utente esistente.\n')
  27.             return
  28.     nome = input('Nome: ')
  29.     cognome = input('Cognome: ')
  30.     eta = input('Eta\'; ')
  31.  
  32.     d[cf] = Utente(nome,cognome,eta)
  33.     u_d[cf] = []
  34.  
  35. def inserisci_dispositivo(utenti,disp,u_d):
  36.     imei = input('IMEI: ')
  37.     if imei in disp:
  38.         print('Dispositivo esistente.\n')
  39.         return
  40.  
  41.     prod = input('Produttore: ')
  42.     mod = input('Modello: ')
  43.  
  44.     try:
  45.         if input('E\' uno spartphone (\'s\' = si)?') == 's':
  46.  
  47.             lun = int(input('Lunghezza schermo: '))
  48.             lar = int(input('Larghezza schermo: '))
  49.             anno = int(input('Anno: '))
  50.  
  51.             disp[imei] = Smartphone(prod,mod,[lun,lar],anno)
  52.         else:
  53.             disp[imei] = Telefono(prod,mod)
  54.  
  55.         cf = input('CF: ')
  56.         if cf in utenti:
  57.             u_d[cf].append(imei)
  58.         elif input('Utente non trovato. Creare (\'s\' = si)?') == 's':
  59.             inserisci_utente(utenti,u_d,cf)
  60.             u_d[cf].append(imei)
  61.         else:
  62.             del disp[imei]
  63.             print('Dispositivo eliminato.')
  64.  
  65.     except ValueError:
  66.         print('Inserimento non valido.')
  67.  
  68. def elimina_utente(utenti,dispositivi,u_d):
  69.     cf = input('CF dell\'utente da eliminare: ')
  70.  
  71.     if cf in utenti:
  72.         imei = u_d[cf]
  73.         for k in imei:
  74.             del dispositivi[k]
  75.         del u_d[cf]
  76.         del utenti[cf]
  77.     else:
  78.         print('Utente non trovato.')
  79.  
  80. def cerca(dispositivi):
  81.     area_max = 0
  82.     imei_max = None
  83.     for imei in dispositivi:
  84.         if isinstance(dispositivi[imei],Smartphone):
  85.             schermo = dispositivi[imei].getSchermo()
  86.             if schermo[0]*schermo[1] >= area_max:
  87.                 imei_max = imei
  88.                 area_max = schermo[0]*schermo[1]
  89.     if imei_max:
  90.         print(dispositivi[imei_max])
  91.  
  92. def main():
  93.     utenti = {}
  94.     dispositivi = {}
  95.     u_d = {}
  96.     scelta = menu()
  97.     while scelta != ESCI:
  98.         if scelta == INSERISCI_UTENTE:
  99.             inserisci_utente(utenti,u_d)
  100.         elif scelta == INSERISCI_DISPOSITIVO:
  101.             inserisci_dispositivo(utenti,dispositivi,u_d)
  102.         elif scelta == ELIMINA_UTENTE:
  103.             elimina_utente(utenti,dispositivi,u_d)
  104.         elif scelta == CERCA_AREA:
  105.             cerca(dispositivi)
  106.         else:
  107.             print('Scelta non valida.\n')
  108.         scelta = menu()
  109.  
  110. main()


Appello 5 Novembre 2018

Esercizio 4: Si ha la necessità di gestire due tipologie, mutuamente esclusive, di iscritti a una conferenza: “Partecipante” e “Speaker”, mantenendo traccia delle informazioni anagrafiche: nome, cognome e CF (16 valori alfanumerici). Per ogni tipologia è necessario gestire le seguenti informazioni aggiuntive:

  • per Partecipante è necessario conoscere la modalità di iscrizione (“Studente” o “Full”) e il costo di iscrizione;
  • per Speaker è necessario conoscere l’affiliazione.

Si modelli il problema secondo i paradigmi della programmazione orientata agli oggetti e si scelga una opportuna struttura dati per memorizzare partecipanti e speaker; si scriva quindi il codice Python dell’algoritmo che:

  1. definisce in maniera opportuna le classi partecipante e speaker;
  2. permette di inserire un nuovo iscritto;
  3. permette di cancellare un iscritto;
  4. permette di modificare la modalità di iscrizione dei partecipanti da studente a full e vice versa;
  5. permette di cercare uno speaker e di stampare le relative informazioni;
  6. permette di calcolare il numero di partecipanti iscritti in base alla modalità di iscrizione;
  7. permette di salvare in un unico file binario tutte le informazioni raccolte;
  8. gestisce le eccezioni che possono essere generate;
  9. richiama le funzioni implementate mediante un menu.

Codice Python

Di seguito il codice Python che implementa la classe Iscritto.

  1. class Iscritto:
  2.     def __init__(self,nome, cognome):
  3.         self.__nome = nome
  4.         self.__cognome = cognome
  5.  
  6.     def seNome(self,nome):
  7.         self.__nome = nome
  8.  
  9.     def setCognome(self,cognome):
  10.         self.__cognome = cognome
  11.  
  12.     def getNome(self):
  13.         return self.__nome
  14.  
  15.     def getCognome(self):
  16.         return self.__cognome
  17.  
  18.     def __str__(self):
  19.         return 'Nome: ' + self.__nome + '\nCognome: ' + self.__cognome + '\n'

Di seguito il codice Python che implementa le classi Partecipante e Speaker.

  1. from iscritto import Iscritto
  2.  
  3. class Partecipante(Iscritto):
  4.     def __init__(self,nome, cognome, tipologia, costo):
  5.         Iscritto.__init__(self,nome, cognome)
  6.         self.__tipologia = tipologia
  7.         self.__costo = costo
  8.  
  9.     def setTipologia(self,tipologia):
  10.         self.__tipologia = tipologia
  11.  
  12.     def setCosto(self,costo):
  13.         self.__costo = costo
  14.  
  15.     def getTipologia(self):
  16.         return self.__tipologia
  17.  
  18.     def getCosto(self):
  19.         return self.__costo
  20.  
  21.     def __str__(self):
  22.         return Iscritto.__str__(self) + 'Tipologia: ' + self.__tipologia + '\nCosto: ' + self.__costo + '\n'
  23.  
  24.  
  25. class Speaker(Iscritto):
  26.     def __init__(self,nome, cognome, affiliazione):
  27.         Iscritto.__init__(self, nome, cognome)
  28.         self.__affiliazione = affiliazione
  29.  
  30.     def setAffiliazione(self,affialiazione):
  31.         self.__affiliazione = affialiazione
  32.  
  33.     def getAffiliazione(self):
  34.         return self.__affiliazione
  35.  
  36.     def __str__(self):
  37.         return Iscritto.__str__(self) + 'Affiliazione: ' + self.__affiliazione + '\n'

Di seguito la funzione main.

  1. import pickle
  2.  
  3. from categorie import Partecipante, Speaker
  4.  
  5. INS = 1
  6. CANC = 2
  7. MOD = 3
  8. CERCA = 4
  9. CALCOLA = 5
  10. SALVA = 6
  11. ESCI = 7
  12.  
  13. def menu():
  14.     print('1) Inserisci')
  15.     print('2) Cancella')
  16.     print('3) Modifica')
  17.     print('4) Cerca')
  18.     print('5) Calcola')
  19.     print('6) Salva')
  20.     print('7) Esci')
  21.  
  22.     try:
  23.         c = int(input('Scelta: '))
  24.         return c
  25.     except ValueError:
  26.         return 0
  27.  
  28.  
  29. def inserisci(p,s):
  30.  
  31.     cf = input('Inserisci CF: ')
  32.  
  33.     if len(cf) != 16:
  34.         print('CF non valido.')
  35.     elif cf in p:
  36.         print('Partecipante già inserito.')
  37.     elif cf in s:
  38.         print('Speaker già inserito.')
  39.     else:
  40.         nome = input('Nome: ')
  41.         cognome = input('Cognome: ')
  42.  
  43.         m = ''
  44.         while m != 'p' and m != 's' and m != 'a':
  45.             m = input('Tipologia (p = \'partecipante\', s = \'speaker\', a = \'annulla\'):')
  46.  
  47.         if m == 'p':
  48.             tipologia = ''
  49.             while tipologia != 's' and tipologia != 'f' and tipologia != 'a':
  50.                 tipologia = input('Tipologia (s = \'studente\', f = \'full\', a = \'annulla\'):')
  51.  
  52.             costo = -1
  53.             while costo < 0:
  54.                 try:
  55.                     costo = float(input('Costo: '))
  56.                     if costo < 0:
  57.                         raise ValueError
  58.                 except ValueError:
  59.                     print('Costo non valido.')
  60.  
  61.             p[cf] = Partecipante(nome,cognome,tipologia,costo)
  62.  
  63.         elif m == 's':
  64.             affiliazion = input('Affiliazion: ')
  65.             s[cf] = Speaker(nome, cognome, affiliazion)
  66.  
  67.  
  68. def cancella(p,s):
  69.     cf = input('Inserisci CF dell\'iscritto che si vuole cancellare: ')
  70.  
  71.     if cf in p:
  72.         del p[cf]
  73.     elif cf in s:
  74.         del s[cf]
  75.     else:
  76.         print('CF non presente.')
  77.  
  78.  
  79. def modifica(p):
  80.     cf = input('Inserisci CF del partecipante da modificare: ')
  81.  
  82.     if cf in p:
  83.         if p[cf].getTipologia() == 's':
  84.             p[cf].setTipologia('f')
  85.             print('studente --> full')
  86.         else:
  87.             p[cf].setTipologia('s')
  88.             print('full --> studente')
  89.     else:
  90.         print('CF non presente.')
  91.  
  92.  
  93. def cerca(s):
  94.     cf = input('Inserisci CF dello speaker da cercare: ')
  95.  
  96.     if cf in s:
  97.         print(s[cf])
  98.     else:
  99.         print('CF non presente.')
  100.  
  101.  
  102. def calcola(p):
  103.     tipologia = ''
  104.     while tipologia != 's' and tipologia != 'f' and tipologia != 'a':
  105.         tipologia = input('Tipologia (s = \'studente\', f = \'full\', a = \'annulla\'):')
  106.  
  107.     if tipologia != 'a':
  108.         s = 0
  109.         for cf in p:
  110.             if p[cf].getTipologia() == tipologia:
  111.                 s += 1
  112.         print('Il numero di iscritti per la tipologia richiesta è: ',s)
  113.  
  114.  
  115. def salva(p,s):
  116.     filename = input('Inserisci il nome del file in cui salvare (.dat): ')
  117.     try:
  118.         fid = open(filename,'wb')
  119.         pickle.dump(p,fid)
  120.         pickle.dump(s, fid)
  121.         fid.close()
  122.     except IOError:
  123.         print('Errore nella scrittura del file.')
  124.  
  125.  
  126. def main():
  127.     partecipanti = {}
  128.     speaker = {}
  129.  
  130.     c = 0
  131.  
  132.     while c != ESCI:
  133.         c = menu()
  134.         if c == INS:
  135.             inserisci(partecipanti,speaker)
  136.         elif c == CANC:
  137.             cancella(partecipanti,speaker)
  138.         elif c == MOD:
  139.             modifica(partecipanti)
  140.         elif c == CERCA:
  141.             cerca(speaker)
  142.         elif c == CALCOLA:
  143.             calcola(partecipanti)
  144.         elif c == SALVA:
  145.             salva(partecipanti,speaker)
  146.         elif c == ESCI:
  147.             pass
  148.         else:
  149.             print('Scelta non valida.')
  150.  
  151. main()


Appello 7 Gennaio 2019

Esercizio 4: Si ha la necessità di gestire un servizio di autonoleggio. In particolare è necessario tenere traccia dei clienti e dei veicoli noleggiati. Per ogni cliente è necessario tenere traccia delle seguenti informazioni: nome, cognome, età, numero patente e CF. Per quanto riguarda i veicoli, invece, distinguiamo due tipologie “Utilitaria” e “Lusso” e per ognuna di esse è necessario conoscere le seguenti informazioni:

  • per Utilitaria è necessario conoscere targa, modello e costo;
  • per Lusso è necessario conoscere targa, modello, costo e accessori (lista di elementi).

Si modelli il problema secondo i paradigmi della programmazione orientata agli oggetti e si scelga una opportuna struttura dati per memorizzare i clienti, i veicoli e i noleggi effettuati; si scriva quindi il codice Python dell’algoritmo che:

  1. definisce in maniera opportuna le classi cliente e veicolo;
  2. permette di inserire un nuovo veicolo;
  3. permette di inserire un nuovo cliente (se non esistente) e di associare il veicolo noleggiato;
  4. permette di calcolare il numero di veicoli noleggiati da clienti con età superiore ad anni 24;
  5. permette di calcolare il consto totale dei veicoli noleggiati;
  6. gestisce le eccezioni che possono essere generate;
  7. richiama le funzioni implementate mediante un menu .

Codice Python

Di seguito il codice Python che implementa la classe Cliente.

  1. class Cliente:
  2.     def __init__(self,nome,cognome,eta,n_patente):
  3.         self.__nome = nome
  4.         self.__cognome = cognome
  5.         self.__eta = eta
  6.         self.__n_patente = n_patente
  7.  
  8.     def setNome(self,nome):
  9.         self.__nome = nome
  10.  
  11.     def setCognome(self,cognome):
  12.         self.__cognome = cognome
  13.  
  14.     def setEta(self,eta):
  15.         self.__eta = eta
  16.  
  17.     def setNPatente(self,n_patente):
  18.         self.__n_patente = n_patente
  19.  
  20.     def getNome(self):
  21.         return self.__nome
  22.  
  23.     def getCognome(self):
  24.         return self.__cognome
  25.  
  26.     def getEta(self):
  27.         return self.__eta
  28.  
  29.     def getNPatente(self):
  30.         return self.__n_patente
  31.  
  32.     def __str__(self):
  33.         return "Nome: " + self.__nome + "\nCognome: " + self.__cognome + "\nEta': " + str(self.__eta) + "\nNumero Patente: " + self.__n_patente + "\n"

Di seguito il codice Python che implementa le classi Utilitaria e Lusso.

  1. class Utilitaria:
  2.     def __init__(self,modello,costo):
  3.         self.__modello = modello
  4.         self.__costo = costo
  5.  
  6.     def setModello(self,modello):
  7.         self.__modello = modello
  8.  
  9.     def setCosto(self,costo):
  10.         self.__costo = costo
  11.  
  12.     def getModello(self):
  13.         return self.__modello
  14.  
  15.     def getCosto(self):
  16.         return self.__costo
  17.  
  18.     def __str__(self):
  19.         return "Modello: " + self.__modello + "\nCosto: " + str(self.__costo) + "\n"
  20.  
  21.  
  22. class Lusso(Utilitaria):
  23.     def __init__(self,modello,costo,accessori):
  24.         Utilitaria.__init__(self,modello,costo)
  25.         self.__accessori = accessori
  26.  
  27.     def setAccessori(self,accessori):
  28.         self.__accessori = accessori
  29.  
  30.     def getAccessori(self):
  31.         return self.__accessori
  32.  
  33.     def __str__(self):
  34.         out = Utilitaria.__str__(self)
  35.  
  36.         for i in self.__accessori:
  37.             out = out + str(i) + "\n"
  38.  
  39.         return out

Di seguito la funzione main.

  1. from cliente import Cliente
  2. from veicolo import Utilitaria, Lusso
  3.  
  4. INSERISCI_VEICOLO = 1
  5. NUOVO_NOLEGGIO = 2
  6. ETA = 3
  7. COSTO = 4
  8. ESCI = 5
  9.  
  10. def menu():
  11.     print("1) Inserisci nuovo veicolo;")
  12.     print("2) Nuovo noleggio;")
  13.     print("3) Conta;")
  14.     print("4) Calcola costo;")
  15.     print("5) Esci.")
  16.  
  17.     try:
  18.         return int(input("Scelta: "))
  19.     except ValueError:
  20.         return 0
  21.  
  22. def inserisci_veicolo(d):
  23.     targa = input("Inserisci targa: ")
  24.  
  25.     if targa in d:
  26.         print("Veicolo Esistente.")
  27.         return
  28.  
  29.     modello = input("Inserisci modello: ")
  30.  
  31.     try:
  32.         costo = int(input("Inserisci costo: "))
  33.     except ValueError:
  34.         print("Valore non valido.")
  35.         return
  36.  
  37.     c = ''
  38.     while c != 'u' and c != 'l' and c != 'a':
  39.         c =input("\"u\" = utilitaria, \"l\" = lusso, \"a\" = annulla: ")
  40.  
  41.     if c == 'u':
  42.         d[targa] = Utilitaria(modello,costo)
  43.     elif c == 'l':
  44.         accessori = []
  45.  
  46.         c = ''
  47.         while c != 'n':
  48.             accessori.append(input("Accessorio: "))
  49.             c = input("Nuovo accessorio (\"s\" = si, \"n\" = no): ")
  50.  
  51.         d[targa] = Lusso(modello,costo,accessori)
  52.  
  53. def inserisci_dati_cliente():
  54.     nome = input("Nome: ")
  55.     cognome = input("Cognome: ")
  56.     try:
  57.         eta = int(input("Eta': "))
  58.     except ValueError:
  59.         print("Vaolre non valido.")
  60.         return -1
  61.     else:
  62.         npat = input("Numero patente: ")
  63.         return Cliente(nome,cognome,eta,npat)
  64.  
  65. def nuovo_cliente(clienti,noleggi):
  66.     cf = input("CF: ")
  67.     if cf not in clienti:  # Nuovo cliente
  68.         cliente = inserisci_dati_cliente()
  69.         if isinstance(cliente, Cliente):
  70.             clienti[cf] = cliente
  71.             noleggi[cf] = []
  72.             print("Cliente creato.")
  73.     return cf
  74.  
  75.  
  76. def nuovo_noleggio(clienti,veicoli,noleggi):
  77.     targa = input("Targa: ")
  78.     if targa in veicoli: # Il veicolo esiste
  79.  
  80.         for cf in noleggi:
  81.             if targa in noleggi[cf]: # Veicolo non noleggiabile
  82.                 print("Veicolo non noleggiabile.")
  83.                 return
  84.  
  85.         cf = nuovo_cliente(clienti, noleggi)
  86.         if cf in clienti:  # Cliente esistente
  87.             noleggi[cf].append(targa)
  88.  
  89.     else:
  90.         print ("Veicolo non trovato.")
  91.  
  92.  
  93. def conta(clienti,noleggi):
  94.     count = 0
  95.     for cf in noleggi:
  96.         if clienti[cf].getEta() > 24:
  97.             count += len(noleggi[cf])
  98.     print("Numero clienti: ",count)
  99.  
  100. def somma_costo(veicoli,noleggi):
  101.     targhe_nol = []
  102.     for cf in noleggi:
  103.         targhe_nol += noleggi[cf]
  104.  
  105.     count = 0
  106.     for targa in targhe_nol:
  107.         count += veicoli[targa].getCosto()
  108.  
  109.     print("Costo totale: ",count)
  110.  
  111.  
  112. def main():
  113.     clienti = {}
  114.     veicoli = {}
  115.     noleggi = {}
  116.  
  117.     c = menu()
  118.     while c != ESCI:
  119.         if c == INSERISCI_VEICOLO:
  120.             inserisci_veicolo(veicoli)
  121.         elif c == NUOVO_NOLEGGIO:
  122.             nuovo_noleggio(clienti,veicoli,noleggi)
  123.         elif c == ETA:
  124.             conta(clienti,noleggi)
  125.         elif c == COSTO:
  126.             somma_costo(veicoli, noleggi)
  127.         else:
  128.             print("Scelta non valida")
  129.  
  130.         c = menu()
  131.  
  132. main()


Appello 4 Febbraio 2019

Esercizio 4: Si ha la necessità di gestire la mailing list di un sito istituzionale. In particolare è necessario gestire tre tipologie di iscrizioni: “Guest”, “Studente” e “Docente”. Per potersi iscrivere ad ogni mailing list ogni utente deve fornire le seguenti informazioni: nome, cognome, anno di nascita ed indirizzo email. In base alla tipologia di utente, inoltre, sono necessarie le seguenti informazioni aggiuntive:

  • Guest: tipo di documento d’identità (passaporto o carta d’identità), numero documento;
  • Studente: matricola e corso di studi;
  • Docente: codice fiscale (16 valori alfanumerici) e dipartimento di afferenza.

Si modelli il problema secondo i paradigmi della programmazione orientata agli oggetti e si scelga una opportuna struttura dati per memorizzare le tre tipologie di utente; si scriva quindi il codice Python dell’algoritmo che:

  1. definisce la classe utente;
  2. definisce in maniera opportuna le classi Guest, Studente e Docente;
  3. permette di inserire un nuovo iscritto;
  4. permette di eliminare un iscritto;
  5. permette di cercare e stampare il codice fiscale di ogni docente in base al dipartimento richiesto;
  6. permette di cercare e stampare tutti gli indirizzi email degli studenti nati in un determinato intervallo temporale;
  7. gestisce le eccezioni che possono essere generate;
  8. richiama le funzioni implementate mediante un menu;

Codice Python

Di seguito il codice Python che implementa la classe Cliente.

  1. class Utente:
  2.     def __init__(self,nome,cognome,anno):
  3.         self.__nome = nome
  4.         self.__cognome = cognome
  5.         self.__anno = anno
  6.  
  7.     def setNome(self,nome):
  8.         self.__nome = nome
  9.  
  10.     def setCognome(self,cognome):
  11.         self.__cognome = cognome
  12.  
  13.     def setAnno(self,anno):
  14.         self.__anno = anno
  15.  
  16.     def getNome(self):
  17.         return self.__nome
  18.  
  19.     def getCognome(self):
  20.         return self.__cognome
  21.  
  22.     def getAnno(self):
  23.         return self.__anno
  24.  
  25.     def __str__(self):
  26.         return 'Nome: ' + self.__nome + '\nCognome: ' + self.__cognome + '\nAnno: ' + self.__anno + '\n'

Di seguito il codice Python che implementa le classi Guest, Studente e Docente.

  1. from utente import Utente
  2.  
  3. class Guest(Utente):
  4.     def __init__(self,nome,cognome,anno,tipo,doc):
  5.         Utente.__init__(self,nome,cognome,anno)
  6.         self.__tipo = tipo
  7.         self.__doc = doc
  8.  
  9.     def setTipo(self,tipo):
  10.         self.__tipo == tipo
  11.  
  12.     def setDoc(self,doc):
  13.         self.__doc = doc
  14.  
  15.     def getTipo(self):
  16.         return self.__tipo
  17.  
  18.     def getDoc(self):
  19.         return self.__doc
  20.  
  21.     def __str__(self):
  22.         Utente.__str__(self) + '\nTipo: ' + self.__tipo + '\nDoc: ' + self.__doc + '\n'
  23.  
  24.  
  25. class Studente(Utente):
  26.     def __init__(self,nome,cognome,anno,matricola,corso):
  27.         Utente.__init__(self,nome,cognome,anno)
  28.         self.__matricola = matricola
  29.         self.__corso = corso
  30.  
  31.     def setMatricola(self,matricola):
  32.         self.__matricola == matricola
  33.  
  34.     def setCorso(self,corso):
  35.         self.__corso = corso
  36.  
  37.     def getMatricola(self):
  38.         return self.__matricola
  39.  
  40.     def getCorso(self):
  41.         return self.__corso
  42.  
  43.     def __str__(self):
  44.         Utente.__str__(self) + '\nMatricola: ' + self.__matricola + '\nCorso: ' + self.__corso + '\n'
  45.  
  46.  
  47. class Docente(Utente):
  48.     def __init__(self,nome,cognome,anno,cf,dip):
  49.         Utente.__init__(self,nome,cognome,anno)
  50.         self.__cf = cf
  51.         self.__dip = dip
  52.  
  53.     def setCF(self,cf):
  54.         self.__cf == cf
  55.  
  56.     def setDip(self,dip):
  57.         self.__dip = dip
  58.  
  59.     def getCF(self):
  60.         return self.__cf
  61.  
  62.     def getDip(self):
  63.         return self.__dip
  64.  
  65.     def __str__(self):
  66.         Utente.__str__(self) + '\nCF: ' + self.__cf + '\nDip: ' + self.__dip + '\n'

Di seguito la funzione main.

  1. from iscritto import Guest
  2. from iscritto import Studente
  3. from iscritto import Docente
  4.  
  5.  
  6. INSERISCI = 1
  7. ELIMINA = 2
  8. CERCA_CF = 3
  9. CERCA_EMAIL = 4
  10. ESCI = 5
  11.  
  12.  
  13. def menu():
  14.     print('1) Inserisci: ')
  15.     print('2) Elimina: ')
  16.     print('3) Cerca CF: ')
  17.     print('4) Cerca email: ')
  18.     print('5) Esci: ')
  19.  
  20.     try:
  21.         return int(input('Scelta: '))
  22.     except ValueError:
  23.         return -1
  24.  
  25.  
  26. def inserisci(iscritti):
  27.     email = input('Email: ')
  28.  
  29.     if email in iscritti:
  30.         print('Utente già iscritto.')
  31.     else:
  32.         tipo = ''
  33.  
  34.         while tipo != 'g' and tipo != 's' and tipo != 'd' and tipo != 'a':
  35.             tipo = input('Tipo (g = Guest, s = Studente, d = Docente, a = Annulla): ')
  36.  
  37.         if tipo != 'a':
  38.             nome = input('Nome: ')
  39.             cognome = input('Cognome: ')
  40.             try:
  41.                 anno = int(input('Anno: '))
  42.             except ValueError:
  43.                 print('Anno non valido.')
  44.                 return
  45.  
  46.             if tipo == 'g':
  47.                 tipo_doc = ''
  48.                 while tipo_doc != 'p' and tipo_doc != 'c' and tipo_doc != 'a':
  49.                     tipo_doc = input('Tipo documento (p = Passaporto, c = CI, a = Annulla): ')
  50.  
  51.                 if tipo_doc == 'a':
  52.                     return
  53.  
  54.                 doc = input('Numero documento: ')
  55.  
  56.                 iscritti[email] = Guest(nome,cognome,anno,tipo_doc,doc)
  57.  
  58.             elif tipo == 's':
  59.                 matricola = input('Matricola: ')
  60.                 corso = input('Corso: ')
  61.  
  62.                 iscritti[email] = Studente(nome,cognome,anno,matricola,corso)
  63.  
  64.             else:
  65.                 cf = input('CF: ')
  66.  
  67.                 if len(cf) != 16:
  68.                     return
  69.  
  70.                 dip = input('Dipartimento: ')
  71.  
  72.                 iscritti[email] = Docente(nome,cognome,anno,cf,dip)
  73.  
  74.  
  75. def elimina(iscritti):
  76.     email = input('Email: ')
  77.  
  78.     if email in iscritti:
  79.         del iscritti[email]
  80.  
  81.  
  82. def cerca_cf(iscritti):
  83.     dip = input('Dipartimento: ')
  84.  
  85.     for email in iscritti:
  86.         if isinstance(iscritti[email], Docente):
  87.             if iscritti[email].getDip() == dip:
  88.                 print(iscritti[email].getCF())
  89.  
  90.  
  91. def cerca_email(iscritti):
  92.     try:
  93.         anno1 = int(input('Da (incluso): '))
  94.         anno2 = int(input('A (escluso): '))
  95.     except ValueError:
  96.         print('Anno non valido.')
  97.     else:
  98.         for email in iscritti:
  99.             if isinstance(iscritti[email], Studente):
  100.                 if iscritti[email].getAnno() >= anno1 and iscritti[email].getAnno() < anno2:
  101.                     print(email)
  102.  
  103.  
  104. def main():
  105.  
  106.     iscritti = {}
  107.  
  108.     c = menu()
  109.     while c != ESCI:
  110.         if c == INSERISCI:
  111.             inserisci(iscritti)
  112.         elif c == ELIMINA:
  113.             elimina(iscritti)
  114.         elif c == CERCA_CF:
  115.             cerca_cf(iscritti)
  116.         elif c == CERCA_EMAIL:
  117.             cerca_email(iscritti)
  118.         else:
  119.             print('Scelta non valida.')
  120.  
  121.         c = menu()
  122.  
  123.  
  124. main()