Attenzione! Questa è una Pagina di prova. Le informazioni riportate potrebbero essere incomplete, errate e potenzialmente pericolose. Per contribuire alla realizzazione di questa pagina consultare la discussione di riferimento. |
Guida verificata con Ubuntu: 20.04 22.04
Problemi in questa pagina? Segnalali in questa discussione
Introduzione
In questa pagina vengono mostrati alcuni programmi scritti in Python a difficoltà crescente. Non è per niente una guida alle funzionalità del linguaggio. Se si desidera approfondire le proprie conoscenze, consultare la sezione Ulteriori Risorse.
Questi listati sono scritti per l'interprete Python 3.x; per la guida nella vecchia e deprecata versione Python 2.7 consultare la relativa guida.
Listato 1
Esempio di script minimale: calcola l'area di un triangolo richiedendo all'utente di immettere la misura dei lati.
1 #!/usr/bin/python3
2
3 """ Questa è un'area di commento usata per indicare cosa fa il programma e come.
4
5 Calcola l'area di un triangolo qualsiasi, noti i suoi tre lati.
6 Usa la formula di Erone: sqrt p*(p-a)*(p-b)*(p-c)
7 dove: sqrt = radice quadrata; p = (a+b+c)/2; a,b,c lati
8 """
9
10 # tutto ciò che viene preceduto dal carattere # è
11 # considerato dall'interprete come un commento
12 import math # importa il modulo math; anche questo è un commento
13 a = int(input('inserisci il primo lato '))
14 print('primo lato = ', a)
15 b = int(input('inserisci il secondo lato '))
16 print('secondo lato = ', b)
17 c = int(input('inserisci il terzo lato '))
18 print('terzo lato = ', c)
19 print();
20 print(" ora calcolo l'area di questo triangolo")
21 print()
22 p = (a+b+c) / 2
23 s = math.sqrt(p * (p-a) * (p-b) * (p-c))
24
25 print("l'area del triangolo è " , s)
Listato del programma AreaTriangolo.py
Listato 2
Il programma precedente si interrompe se durante l'inserimento dei dati, per errore, viene digitato un carattere non numerico. Per questo il seguente script, che salviamo col nome AreaTriangolo2.py, inserisce un controllo sul dato immesso.
1 #!/usr/bin/python3
2
3 import math
4 i = 0
5 l = []
6 print("\nInserire le misure dei lati:")
7 while True:
8 a = input(f'\tMisura del {i+1}° lato: ')
9 if not a.isdigit():
10 print("non hai digitato un numero valido. Riprova")
11 continue # ricomincia il ciclo while e ripete la richiesta dello stesso lato
12 # una volta verificato che il dato immesso è una cifra, lo
13 # converte in numero a virgola mobile e lo inserisce in un array
14 l.append(float(a))
15 i += 1
16 if i < 3:
17 continue # ricomincia il ciclo while per passare al successivo lato
18 else:
19 print()
20 print('primo lato = ', l[0])
21 print('secondo lato = ', l[1])
22 print('terzo lato = ', l[2])
23 p = (l[0]+l[1]+l[2]) / 2 # calcola il semiperimetro
24 if p > l[0] and p > l[1] and p > l[2]:
25 break # esce dal ciclo while per fine input
26 else:
27 print("questi dati non possono rappresentare i lati di un triangolo. Riprova:")
28 i = 0
29 l = []
30 continue # ricomincia il ciclo while per acquisire di nuovo tutti i lati
31
32 s = math.sqrt(p * (p-l[0]) * (p-l[1]) * (p-l[2]))
33 print("l'area di questo triangolo è " , s)
34 print()
35 print("Fine programma ")
Listato del programma AreaTriangolo2.py
Listato 3
Questa è un'alternativa più efficiente della versione precedente AreaTriangolo2.py: utilizza le classi e la gestione delle eccezioni per eliminare ogni possibilità di errore di immissione senza costringere a immettere solo numeri interi.
1 #!/usr/bin/python3
2
3 from math import sqrt# Importa la funzione sqrt (radice quadrata) dal modulo math
4
5
6 class TriangoloInesistente(Exception):
7 """Classe per sollevare un'eccezione se vengono immesse misure incompatibili."""
8
9 def __init__(self, message="\nUn triangolo con queste misure non esiste. Riprova."):
10 self.message = message
11
12
13 class Triangolo:
14 """Classe per costruire gli oggetti triangolo da calcolare
15
16 Oltre al costruttore, la classe ha due metodi:
17 un metodo che calcola il perimetro e uno che calcola l'area.
18 Attributi della classe sono le misure dei tre lati a, b, c
19 """
20
21 def __init__(self, a, b, c):
22 """Metodo costruttore. In Python i costruttori hanno il nome speciale __init__
23
24 Controlla se i tre valori immessi sono accettabili,
25 cioè se sono validi come misure dei lati di un triangolo.
26 In caso contrario solleva una eccezione TriangoloInesistente.
27 """
28
29 if a + b > c and a + c > b and b + c > a:
30 self.a = a
31 self.b = b
32 self.c = c
33 else:
34 # quando il tipo dei dati è corretto (numeri in virgola mobile)
35 # ma i valori sono incompatibili.
36 raise TriangoloInesistente
37 def perimetro(self):
38 "Metodo che calcola il perimetro"
39 return self.a + self.b + self.c
40
41 def area(self):
42 "Metodo che calcola l'area (tramite formula di Erone)"
43 p = self.perimetro() / 2.0
44 return sqrt(p * (p - self.a) * (p - self.b) * (p - self.c))
45
46
47 while True:
48 # Chiede all'utente di immettere le misure dei lati
49 print("\nInserire le misure dei lati:")
50 lati=[]
51 for lato in 'abc':
52 while True:
53 l = input(f"\tMisura del lato {lato}: ")
54 try :
55 l = float(l)
56 # se viene inserito un valore che non si può trasformare in un numero,
57 # ad esempio una lettera, si solleva l'eccezione ValueError
58 except ValueError:
59 print("\nDevi inserire valori numerici. Riprova.\n")
60 # se invece non è stata sollevata nessuna eccezione
61 # possiamo salvare il valore del lato
62 else:
63 lati.append(l)
64 break
65 try:
66 # Crea una nuova istanza della classe Triangolo.
67 # In pratica facciamo una chiamata al suo metodo costruttore:
68 # sarebbe stato lo stesso scrivere "triangolo = Triangolo.__init__(a,b,c)"
69 triangolo = Triangolo(lati[0], lati[1], lati[2])
70 # qua gestiamo l'eccezione che potrebbe sollevarsi nella classe Triangolo
71 except TriangoloInesistente as err:
72 #"err" è l'oggetto creato da Python durante il verificarsi dell'errore
73 print(err.message)
74 continue
75 # Utilizza i metodi definiti nella classe per ottenere perimetro ed area
76 # dell'oggetto triangolo e stampa a video i risultati.
77 print()
78 print("Perimetro = ", triangolo.perimetro())
79 print("Area = ", triangolo.area())
80
81 # Chiede all'utente se intende terminare il programma.
82 exit = input("\nUscire [digitare 's' per confermare]? ")
83 print("")
84 if exit == "s": break
Listato del programma AreaTriangolo2ConEccezioni.py
Listato 4
Ora supponiamo di dover calcolare l'area di un appezzamento di terreno scomposto in un numero finito di triangoli.
Una volta nota l'area, supponiamo che debba essere divisa, per volontà testamentaria, in tre parti in funzione dell'età di tre fratelli.
Useremo come base lo script AreaTriangolo2.py, con qualche modifica o aggiunta; lo salveremo come AreaTriangolo3.py.
1 #!/usr/bin/python3
2
3 from math import sqrt
4
5 ### fase di input
6 nomi = []
7 fratelli =[]
8 lati= []
9 x = 1
10 while x <= 3:
11 a = input(f' Inserici il nome del {x}° fratello: ')
12 if not a.isalpha():
13 print(" Errore nell'immettere il nome. Riprova")
14 continue # ricomincia il ciclo while per reinserire il nome che era errato
15 nomi.append(a.title()) # salva nella lista nomi il nome (con iniziale maiuscola)
16 x += 1
17
18 for nome in nomi:
19 a = ""
20 while not a.isdigit():
21 a = input(f" Inserisci l'età di {nome}: ")
22 if not a.isdigit():
23 print(" Non hai digitato un numero valido. Riprova")
24
25 fratelli.append((nome, int(a)))
26 for n, e in fratelli:
27 print(f' Età di {n}: {e}', end=" ")
28 print('\n')
29 #input dei dati per il calcolo dell'area dell'appezzamento
30 tria = []
31 n_tri = 0
32 si = ''
33 while si != "S":
34 n_tri += 1
35 lati = []
36 p = 0
37 for i in range(1, 4):
38 while True:
39 try:
40 a = input(f' Inserisci il {i}° lato del {n_tri}° triangolo: ')
41 lati.append(float(a))
42 except ValueError:
43 print(" Non hai digitato un numero valido. Riprova")
44 continue #continua il ciclo while costringendo a reimmettere il dato
45 break
46 # terminato l'input dei dati del triangolo
47 # li ripresenta a video per maggior chiarezza
48 for i, lato in enumerate(lati):
49 print(f' {i + 1}° lato = {lato}', end=" ")
50 p += lato / 2
51 if not p > lati[0] and p > lati[1] and p > lati[2]:
52 print("\n Questi dati non rappresentano i lati di un triangolo. Riprova")
53 continue # ricomincia il ciclo while perché i dati immessi erano errati
54 tria.append(lati)
55 print('\n')
56 si = input(" hai finito di immettere i triangoli? conferma con S/s ").upper()
57
58 ### fase di calcolo area appezzamento
59 # il calcolo dell'area verrà ripetuto una volta per triangolo
60 stot = 0
61 for i, lati in enumerate(tria):
62 p = 0
63 print(f"\n {i + 1}° triangolo\n Lati:", end=' ')
64 for lato in lati:
65 print(lato, end=' ')
66 p += lato / 2.0
67 print()
68 s = sqrt(p * (p-lati[0]) * (p-lati[1]) * (p-lati[2]))
69 print(f" Area = {s}")
70 stot += s
71 print(f"\n L'area totale dell'appezzamento di terreno è di mq {stot:<15.2f}")
72 print(" quanto terreno spetta a ciascuno dei tre fratelli in base all'età:")
73
74 seta = sum([eta for n, eta in fratelli]) # somma delle età dei fratelli
75 areau = stot / seta # rapporto tra area totale e somma delle età
76
77 for fratello in fratelli:
78 nome, eta = fratello
79 area = areau * eta
80 print(f"\n l'area spettante a {nome} somma {area:<10.2f}")
81
82 print()
83 print(' Fine programma ')
Listato del programma AreaTriangolo3.py
Ulteriori risorse
È possibile anche scrivere applicazioni dotate di interfaccia grafica, per informazioni consultare la relativa guida.