day_1.md 10.6 KB
Newer Older
Tancredi Orlando's avatar
Tancredi Orlando committed
1
2
3
4
5
6
7
8
# Corsi Python 2017

----

Potete ottenere questa presentazione recandovi all'indirizzo:

[slides.poul.org/2017/python](https://slides.poul.org/2017/python)

edne's avatar
edne committed
9
---
Tancredi Orlando's avatar
Tancredi Orlando committed
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25

# Perché Python?

- Ottimo per i principianti
- Facile da usare
- Estremamente diffuso
- Moduli per qualunque cosa

----

## C

```c
#include <stdio.h>

int main() {
Niccolò Izzo's avatar
Niccolò Izzo committed
26
    printf("Hello, world!\n");
Tancredi Orlando's avatar
Tancredi Orlando committed
27
28
29
30
31
32
33
34
35
36
37
    return 0;
}
```

----

## Java

```java
public class HelloWorld {
    public static void main(String[] args) {
Niccolò Izzo's avatar
Niccolò Izzo committed
38
        System.out.println("Goodbye, world!");
Tancredi Orlando's avatar
Tancredi Orlando committed
39
40
41
42
43
44
45
46
47
    }
}
```

----

## Python

```python
Niccolò Izzo's avatar
Niccolò Izzo committed
48
print('Hello, world!')
Tancredi Orlando's avatar
Tancredi Orlando committed
49
50
51
52
53
54
55
56
57
58
59
60
61
62
```

----

![import antigravity](https://imgs.xkcd.com/comics/python.png)

----

## Breve storia

- Nasce nel 1991 per mano di Guido van Rossum
- Prende il nome dai Monty Python
- È in continua evoluzione
- Convivono due versioni (2 e 3)
edne's avatar
edne committed
63
- Noi useremo Python 3
Tancredi Orlando's avatar
Tancredi Orlando committed
64
65
66
- Fatelo anche voi

Notes:
edne's avatar
edne committed
67
68
- Ricordatevi il nome di Guido
- Aggiungere statistiche sullo sviluppo di python
Tancredi Orlando's avatar
Tancredi Orlando committed
69
70
71
72
73
74
75

----

## Interpretato vs. compilato

- Compilato: tradotto in linguaggio macchina
- Interpretato: eseguito da un altro programma
edne's avatar
edne committed
76
- Python è interpretato (circa)
Tancredi Orlando's avatar
Tancredi Orlando committed
77
78

Notes:
edne's avatar
edne committed
79
- Parlare della VM Python
Tancredi Orlando's avatar
Tancredi Orlando committed
80

edne's avatar
edne committed
81
----
Tancredi Orlando's avatar
Tancredi Orlando committed
82
83
84
85

## Cosa serve

- Editor di testo (Atom, Notepad++)
Niccolò Izzo's avatar
Niccolò Izzo committed
86
- Interprete Python:
Tancredi Orlando's avatar
Tancredi Orlando committed
87
88
89
90
91
  - Linux: generalmente preinstallato, altrimenti utilizzare il package manager
  - macOS: [Installer](https://www.python.org/ftp/python/3.6.1/python-3.6.1-macosx10.6.pkg)
  - Windows: [32bit](https://www.python.org/ftp/python/3.6.1/python-3.6.1.exe)
    o [64bit](https://www.python.org/ftp/python/3.6.1/python-3.6.1-amd64.exe)

edne's avatar
edne committed
92
93
94
95
---

# Vediamo il linguaggio

Tancredi Orlando's avatar
Tancredi Orlando committed
96
97
98
99
100
101
102
103
104
105
----

## REPL

**R**ead, **E**val, **P**rint **L**oop

```bash
$ python3
Python 3.6.1 (default, Mar 27 2017, 00:27:06) 
[GCC 6.3.1 20170306] on linux
Niccolò Izzo's avatar
Niccolò Izzo committed
106
107
Type "help", "copyright", "credits" or "license" for more info...
>>> print('Hello, world!')
Tancredi Orlando's avatar
Tancredi Orlando committed
108
109
110
Hello world!
```

edne's avatar
edne committed
111
Per uscire: `quit()`
Tancredi Orlando's avatar
Tancredi Orlando committed
112
113

Notes:
edne's avatar
edne committed
114
- Differenza tra interprete (il software che converte le istruzioni in bytecode e
Tancredi Orlando's avatar
Tancredi Orlando committed
115
116
117
118
119
120
poi esegue quest'ultimo) e REPL (il software che si interfaccia con l'utente)

----

## Espressioni

edne's avatar
edne committed
121
```
Tancredi Orlando's avatar
Tancredi Orlando committed
122
123
>>> 2 + 2
4
edne's avatar
edne committed
124

Tancredi Orlando's avatar
Tancredi Orlando committed
125
126
>>> 3 * 3
9
edne's avatar
edne committed
127
128

>>> 4 < 5
Tancredi Orlando's avatar
Tancredi Orlando committed
129
130
131
132
133
True
```

----

edne's avatar
edne committed
134
135
## Commenti

edne's avatar
edne committed
136
137
138
Tutto quello scritto dopo il `#` non viene interpretato

```python
edne's avatar
edne committed
139
>>> 1 + 1  # qui posso scrivere quello che voglio
edne's avatar
edne committed
140
141
142
2
```

edne's avatar
edne committed
143
144
----

Tancredi Orlando's avatar
Tancredi Orlando committed
145
146
## Errori

edne's avatar
edne committed
147
```
Tancredi Orlando's avatar
Tancredi Orlando committed
148
149
150
151
152
153
>>> 3 / 0
Traceback (most recent call last):
  File "<stdin>", line 1, in <module>
ZeroDivisionError: division by zero
```

Niccolò Izzo's avatar
Niccolò Izzo committed
154
Il segreto degli hacker? Leggere le scritte!
edne's avatar
edne committed
155

Tancredi Orlando's avatar
Tancredi Orlando committed
156
157
158
159
160
161
162
163
([Lettura consigliata](http://www.girodivite.it/Diario-di-un-aspirante-hacker.html))

----

## Variabili

```python
>>> x = 6
edne's avatar
edne committed
164

Tancredi Orlando's avatar
Tancredi Orlando committed
165
166
>>> x
6
edne's avatar
edne committed
167

Tancredi Orlando's avatar
Tancredi Orlando committed
168
169
170
171
>>> 2 * x
12

>>> y = x + 4
edne's avatar
edne committed
172

Tancredi Orlando's avatar
Tancredi Orlando committed
173
174
175
176
>>> y
10
```

edne's avatar
edne committed
177
---
Tancredi Orlando's avatar
Tancredi Orlando committed
178

edne's avatar
edne committed
179
180
181
182
183
# Tipi

----

## Cosa ho di fronte?
Tancredi Orlando's avatar
Tancredi Orlando committed
184

edne's avatar
edne committed
185
```
Tancredi Orlando's avatar
Tancredi Orlando committed
186
187
188
189
190
191
192
193
194
>>> type(3)
<class 'int'>

>>> type(3.14)
<class 'float'>
```

----

edne's avatar
edne committed
195
## Interi (`int`)
edne's avatar
edne committed
196

Niccolò Izzo's avatar
Niccolò Izzo committed
197
198
- Cifre senza punto

edne's avatar
edne committed
199
```
Niccolò Izzo's avatar
Niccolò Izzo committed
200
201
202
12       # notazione decimale
0xAB     # notazione esadecimale
0b101    # notazione binaria
edne's avatar
edne committed
203
```
edne's avatar
edne committed
204
205
206

----

edne's avatar
edne committed
207
## Decimali (`float`)
edne's avatar
edne committed
208
209
210
211
212
213
214
215
216

- Cifre con punto

```
>>> 3.14 + 1.234
4.3740000000000006

>>> 100 / 3
33.333333333333336
Tancredi Orlando's avatar
Tancredi Orlando committed
217

edne's avatar
edne committed
218
219
220
>>> 100 // 3
33
```
Tancredi Orlando's avatar
Tancredi Orlando committed
221
222
223

----

edne's avatar
edne committed
224
## Casting
edne's avatar
edne committed
225
226

- È l'azione di conversione del tipo
edne's avatar
edne committed
227
- Si usa il nome del tipo destinazione
Tancredi Orlando's avatar
Tancredi Orlando committed
228

edne's avatar
edne committed
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
```
>>> int(4.20)
4

>>> x = float(13)

>>> x
13.0

>>> type(x)
float

>>> type(13)
int
```
Tancredi Orlando's avatar
Tancredi Orlando committed
244
245
246

----

edne's avatar
edne committed
247
## Booleani (`bool`)
Tancredi Orlando's avatar
Tancredi Orlando committed
248

edne's avatar
edne committed
249
250
251
252
253
254
255
256
257
- Possono assumere due valori: `True` o `False`
- Supportano operazioni logiche (`and`, `or`, `not`)
- Sono il risultato delle operazioni di confronto

```
# esempi + corto circuito e quando ti esplode in faccia la vita
# cast a booleano?
```

edne's avatar
edne committed
258
---
edne's avatar
edne committed
259

edne's avatar
edne committed
260
# Collezioni
Tancredi Orlando's avatar
Tancredi Orlando committed
261
262
263

----

edne's avatar
edne committed
264
## Stringhe (`str`)
Tancredi Orlando's avatar
Tancredi Orlando committed
265

Niccolò Izzo's avatar
Niccolò Izzo committed
266
- Testo
edne's avatar
edne committed
267
268
- Racchiuse tra singoli apici (`'`) o virgolette (`"`)
- Per stringhe su più righe racchiuse tra tripli apici (`'''`) o virgolette (`"""`)
edne's avatar
edne committed
269
- Sono immutabili
edne's avatar
edne committed
270
271
272
273
274
275

```
>>> a = "Hello"
>>> b = "World"
>>> a + ' ' + b
'Hello World'
Tancredi Orlando's avatar
Tancredi Orlando committed
276
277
278
279
```

----

edne's avatar
edne committed
280
## Liste (`list`)
Tancredi Orlando's avatar
Tancredi Orlando committed
281

Niccolò Izzo's avatar
Niccolò Izzo committed
282
- Collezione ordinata di elementi, anche di tipi diversi
edne's avatar
edne committed
283
- Si definiscono con le parentesi quadre
Tancredi Orlando's avatar
Tancredi Orlando committed
284

edne's avatar
edne committed
285
```python
edne's avatar
edne committed
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
lista = [false, 1, "due", 3.0, 4, 5]
```

- Per accedere ad un elemento si usano le parentesi quadre
- Il primo elemento ha indice 0

```
>>> lista[2]
'due'
```

- Possono essere modificate

```
>>> lista[0] = 0.0
>>> lista.append('sei')
>>> lista
[0.0, 1, "due", 3.0, 4, 5, 'sei']
Tancredi Orlando's avatar
Tancredi Orlando committed
304
305
306
307
```

----

edne's avatar
edne committed
308
## Tuple (`tuple`)
Tancredi Orlando's avatar
Tancredi Orlando committed
309

Niccolò Izzo's avatar
Niccolò Izzo committed
310
311
- Esattamente come le liste, ma immutabili
- Si definiscono con le parentesi tonde
Tancredi Orlando's avatar
Tancredi Orlando committed
312

edne's avatar
edne committed
313
```python
Tancredi Orlando's avatar
Tancredi Orlando committed
314
315
316
tupla = ('a', 1, 2, 'bcd')
```

edne's avatar
edne committed
317
----
edne's avatar
edne committed
318

edne's avatar
edne committed
319
## Unpacking
edne's avatar
edne committed
320
321
322
323
324
325
326
327
328
329
330
331
332
333

- Estrarre valori da un contenitore

```
>>> t = (1, 2)
>>> a, b = t
>>> b
2

>>> a, b = b, a
>>> b
1
```

Tancredi Orlando's avatar
Tancredi Orlando committed
334
335
----

edne's avatar
edne committed
336
## L'operatore `in`
edne's avatar
edne committed
337

Niccolò Izzo's avatar
Niccolò Izzo committed
338
339
- Valuta l'appartenenza di un elemento ad una collezione

edne's avatar
edne committed
340
341
342
343
344
```
>>> lista = ['a', 'b', 'c']
>>> 'c' in lista
True
```
Niccolò Izzo's avatar
Niccolò Izzo committed
345
346
347
348
349
350
351
352
- È un'espressione booleana
- Si può usare con l'operatore `not`

```
>>> lista = ['a', 'b', 'c']
>>> 'c' not in lista
False
```
edne's avatar
edne committed
353

edne's avatar
edne committed
354
355
----

edne's avatar
edne committed
356
357
## Riferimenti

Niccolò Izzo's avatar
Niccolò Izzo committed
358
- Quando assegniamo un oggetto ad una variabile, la variabile contiene solo un *riferimento* all'oggetto
edne's avatar
edne committed
359
360
361
362
363
364
365
366
367
368
369
370
371

- **Non** l'oggetto stesso.

```python
>>> spesa_a = ['mela', 'mango']
>>> spesa_b = spesa_a
>>> spesa_b.append('carota')
```

```python
>>> spesa_a
['mela', 'mango', 'carota']
```
edne's avatar
edne committed
372
373
374

----

edne's avatar
edne committed
375
## Insiemi (`set`)
Tancredi Orlando's avatar
Tancredi Orlando committed
376

Niccolò Izzo's avatar
Niccolò Izzo committed
377
378
- Come gli insiemi matematici
- Non sono ordinati
Tancredi Orlando's avatar
Tancredi Orlando committed
379
380
- Non contengono elementi duplicati

edne's avatar
edne committed
381
```python
Tancredi Orlando's avatar
Tancredi Orlando committed
382
383
384
insieme = {"mele", "pere", 2, "arance"}
```

edne's avatar
edne committed
385
386
- Supportano operazioni logiche

edne's avatar
edne committed
387
----
Tancredi Orlando's avatar
Tancredi Orlando committed
388

edne's avatar
edne committed
389
## Dizionari (`dict`)
Tancredi Orlando's avatar
Tancredi Orlando committed
390
391
392

- Associano una chiave ad un valore
- Le chiavi devono essere immutabili
edne's avatar
edne committed
393
- I valori possono essere cambiati
Tancredi Orlando's avatar
Tancredi Orlando committed
394

edne's avatar
edne committed
395
```python
edne's avatar
edne committed
396
d = {
Tancredi Orlando's avatar
Tancredi Orlando committed
397
398
399
400
401
    "nome":"Tancredi",
    "cognome":"Orlando"
    }
```

edne's avatar
edne committed
402
403
404
405
406
407
408
- Si accede ai campi usando le chiavi

```
>>> d['nome']
'Tancredi'
```

edne's avatar
edne committed
409
---
Tancredi Orlando's avatar
Tancredi Orlando committed
410

edne's avatar
edne committed
411
# Strutture di controllo
Tancredi Orlando's avatar
Tancredi Orlando committed
412

edne's avatar
edne committed
413
414
Notes:
- parlare di musica
edne's avatar
edne committed
415

Tancredi Orlando's avatar
Tancredi Orlando committed
416
417
----

edne's avatar
edne committed
418
## `if`
Tancredi Orlando's avatar
Tancredi Orlando committed
419

edne's avatar
edne committed
420
421
422
423
424
425
426
427
428
429
430
Se una condizione è vera esegue un blocco di codice

```python
if 3 > 2:
    print('Condizione vera')
```

Notes:
- Dire perché qua stiamo usando `print` e non scrivendo il valore e basta come
  prima

edne's avatar
edne committed
431
## Blocchi
edne's avatar
edne committed
432
433
434
435
Si allineano con quattro spazi

(si possono usare anche 2 o 8 spazi, o i TAB, ma per favore non fatelo)

edne's avatar
edne committed
436
## `else`
edne's avatar
edne committed
437
438
439
440
441
442
443
444

```python
if 3 > 2:
    print('Condizione vera')
else:
    print('Condizione falsa')
```

Tancredi Orlando's avatar
Tancredi Orlando committed
445
446
----

edne's avatar
edne committed
447
## `while`
Tancredi Orlando's avatar
Tancredi Orlando committed
448

edne's avatar
edne committed
449
450
451
452
453
454
455
456
457
458
459
460
Eseguire più volte le stesse istruzioni (fintantoché una condizione è vera)

```python
>>> x = 0
>>> while x < 3:
... 	x = x + 1
... 	print("ora x vale", x)
...
ora x vale 1
ora x vale 2
ora x vale 3
```
Tancredi Orlando's avatar
Tancredi Orlando committed
461

edne's avatar
edne committed
462
----
Tancredi Orlando's avatar
Tancredi Orlando committed
463

edne's avatar
edne committed
464
## `for`
edne's avatar
edne committed
465

edne's avatar
edne committed
466
Cicli di esecuzione sulle sequenze
Tancredi Orlando's avatar
Tancredi Orlando committed
467

edne's avatar
edne committed
468
469
470
471
472
```python
for i in [0, 1, 2, 3, 4]:
	print i
```

edne's avatar
edne committed
473
----
edne's avatar
edne committed
474
475
476
477
478
479
480
481
482
483
484
485
486
487

## `break`, `continue`

* `break`: interrompe l'iterazione
* `continue`: salta all'iterazione successiva

```python
for i in [0, 1, 2, 3, 4, 5, 6, 7]:
	if i == 2:
		continue
	if i == 6:
		break
	print(i)
```
edne's avatar
edne committed
488

edne's avatar
edne committed
489
---
edne's avatar
edne committed
490

edne's avatar
edne committed
491
492
# Funzioni

edne's avatar
edne committed
493
----
edne's avatar
edne committed
494
495
496

## Funzioni

edne's avatar
edne committed
497
498
499
500
501
- Porzioni riusabili di un programma
- Il concetto più importante per costruire un programma
- Ci permettono di dare un nome a un blocco di istruzioni
- E di eseguirlo un numero qualsiasi di volte, "chiamando" la funzione
- Si definiscono con la keyword `def`
edne's avatar
edne committed
502

edne's avatar
edne committed
503
----
edne's avatar
edne committed
504
505
506
507
508
509

## Esempio

```python
def say_hello():
	print('hello world')
edne's avatar
edne committed
510
	
edne's avatar
edne committed
511

edne's avatar
edne committed
512
513
say_hello()  # chiama la funzione
say_hello()  # chiama la funzione di nuovo
edne's avatar
edne committed
514
515
```

edne's avatar
edne committed
516
----
edne's avatar
edne committed
517
518
519
520

## Parametri e Argomenti

- Le funzioni posso specificare dei "parametri"
edne's avatar
edne committed
521
- ogni volta che si chiama la funzione, il loro valore viene assegnato
edne's avatar
edne committed
522
523
- I valori che vengono passati durante la chiamata sono detti "argomenti"

edne's avatar
edne committed
524
525
526
----

## Lo statement `return`
edne's avatar
edne committed
527

edne's avatar
edne committed
528
529
530
531
532
533
534
535
Tramite il `return` la funzione ci dà un risultato

```python
>>> def somma(a, b):
... 	return a + b
...
>>> somma(1, 2)
3
edne's avatar
edne committed
536
537
```

edne's avatar
edne committed
538
539
540
541
Notes:
- è importante che venga visto il `return` il prima possibile
- spiegare comunque la differenza tra restituire un valore e fare una `print`

edne's avatar
edne committed
542
----
edne's avatar
edne committed
543
544
545
546
547
548

## Variabili locali

- Le variabili definite dentro una funzione sono **locali**
- Non sono correlate con variabili dello stesso nome, definite fuori

edne's avatar
edne committed
549
----
edne's avatar
edne committed
550

edne's avatar
edne committed
551
## Lo statement `global`
edne's avatar
edne committed
552
553
554

- Permette di definire una variabile globale all'intero di una funzione

edne's avatar
edne committed
555
----
edne's avatar
edne committed
556

edne's avatar
edne committed
557
558
559

### Argomenti di default

edne's avatar
edne committed
560
561
562
563
- Alcuni parametri possono essere dichiarati opzionali
- Se omettiamo l'argomento, la funzione userà quello di default


edne's avatar
edne committed
564
565
566
567
568
569
570
571
572
573
574
575
576
577
578
579
```python
def f(a, b=3, c=6):
    print(a, b, c)
```

```
>>> f(1)
1 3 6

>>> f(1, 2)
1 2 6

>>> f(1, c=4)
1 3 4
```

edne's avatar
edne committed
580
581
----

edne's avatar
edne committed
582
583
584
## None

- Equivale al `NULL` di C o Java
edne's avatar
edne committed
585
- Valore restituido quando il `return` viene omesso
edne's avatar
edne committed
586

edne's avatar
edne committed
587
---
edne's avatar
Moduli    
edne committed
588
589
590

# Moduli

edne's avatar
edne committed
591
----
edne's avatar
Moduli    
edne committed
592
593
594
595
596
597
598
599
600
601
602
603
604
605
606
607

## Moduli

- Riutilizzare funzioni o tenere un programma ordinato

- Semplicemente un file con estensione .py

- Un modulo può essere importato da un altro programma
 
 
```python
>>> import math
>>> math.sqrt(16)
4.0
```

edne's avatar
edne committed
608
----
edne's avatar
Moduli    
edne committed
609
610

## `from ... import`
edne's avatar
edne committed
611

edne's avatar
Moduli    
edne committed
612
Permette di importare solo alcune funzioni
edne's avatar
edne committed
613

edne's avatar
Moduli    
edne committed
614
615
616
617
618
619
```python
>>> from math import sqrt
>>> sqrt(16)
4.0
```

edne's avatar
edne committed
620
----
edne's avatar
Moduli    
edne committed
621
622
623
624
625
626
627
628
629
630
631
632
633

## La variabile `__name__`

- Contiene il nome del modulo

- Modulo importato o eseguito direttamente?

```python
if __name__ == '__main__':
	print('Programma eseguito direttamente')
else:
	print('Questo modulo è stato importato')
```
edne's avatar
edne committed
634

edne's avatar
edne committed
635
---
edne's avatar
edne committed
636

edne's avatar
edne committed
637
638
639
640
# Input e Output

----

edne's avatar
edne committed
641
## I/O
edne's avatar
edne committed
642

edne's avatar
edne committed
643
644
645
646
647
648
649
650
- A volte può; essere utile interagire con l'utente
- Per esempio chiedere valori in ingresso e stampare risultati
- Useremo `input()` per ricevere dei valori e `print()` per stamparli.

```python
nome = input("Inserisci il tuo nome: ")
print("Il tuo nome è", nome)
```
edne's avatar
edne committed
651

edne's avatar
edne committed
652
653
----

edne's avatar
edne committed
654
655
656
657
658
659
660
661
662
663
664
665
## Formattazione dell'Output

- Per formattare l'output spesso `print()` da sola non è sufficiente.

- Possiamo usare i metodi della classe `str` e in particolare `str.format()`

```python
>>> s = 'This {food} is {adjective}.'.format(
... 	food='spam', adjective='horrible')
>>> print(s)
This spam is horrible
```
edne's avatar
edne committed
666

edne's avatar
edne committed
667
---
edne's avatar
edne committed
668

edne's avatar
edne committed
669
670
# Errori ed Eccezioni

edne's avatar
edne committed
671
----
edne's avatar
edne committed
672
673
674
675
676
677
678
679
680
681
682
683
684
685

## Errori di Sintassi

```python
>>> while return print('Hello?') # ??????
SyntaxError: invalid syntax
```

- Sono i più comuni da commettere per chi sta imparando Python :-)

- Accadono quando scriviamo una istruzione in maniera *sintatticamente* errata

- L'interprete Python non riesce a capirne il significato e quindi non può eseguirla

edne's avatar
edne committed
686
----
edne's avatar
edne committed
687
688

## Eccezioni
edne's avatar
edne committed
689

edne's avatar
edne committed
690
- Rappresentano il verificarsi di situazioni *eccezionali*
edne's avatar
edne committed
691

edne's avatar
edne committed
692
693
- Cosa succede se stiamo tentando di leggere un file che non esiste? O se
  cerchiamo di dividere per zero?
edne's avatar
edne committed
694

edne's avatar
edne committed
695
----
edne's avatar
edne committed
696
697
698
699
700
701
702
703
704
705
706
707

## Gestire le Eccezioni

- Possiamo (e dovremmo) gestire le eccezioni racchiudendo le nostre istruzioni in un blocco `try/except`

```python
try:
	x = int(input('Inserisci un intero: '))
except ValueError:
	print('Oops! Non era un intero.')
```

edne's avatar
edne committed
708
----
edne's avatar
edne committed
709
710
711
712
713
714
715
716
717
718
719
720
721
722
723

## Sollevare Eccezioni

- In alcuni casi può essere utile sollevare delle eccezioni

- Per esempio quando una funzione non è in grado di gestire alcuni input

- Dovranno essere gestite (catturate) dal chiamante della funzione, altrimenti l'utente vedrà un messaggio di errore

```python
def mandaEmail(email, testo):
	if not '@' in email:
		raise ValueError("email non valida")
	# [..]
```
edne's avatar
edne committed
724

edne's avatar
edne committed
725
---
edne's avatar
edne committed
726
727
728

# The End

edne's avatar
edne committed
729
----
edne's avatar
edne committed
730
731
732
733
734

# Thank you!

Queste slides sono sotto licenza Creative Commons<br>
Attribution-ShareAlike 3.0 Unported
Tancredi Orlando's avatar
Tancredi Orlando committed
735

Niccolò Izzo's avatar
Niccolò Izzo committed
736
## [poul.org](https://www.poul.org)