PYTHON BASE
Custom function
Funzioni
Una funzione è un blocco di istruzioni isolate dal resto del
programma che accetta come input uno o più parametri e
restituisce un output, ottenuto dall’esecuzione delle
istruzioni
Programma
Blocco di
istruzioni
INPUT OUTPUT
Funzioni: dichiarazione
def NomeFunzione(P1, P2,…….PN) :
Istruzione 1
Istruzione 2
…………….
Istruzione R
return O1, O2,..... OM
indentazione
INPUT
(parametri)
OUTPUT
(risultato)
Funzioni: chiamata (esecuzione)
R1, R2, … RM = NomeFunzione(A1, A2,…….AN)
INPUT
(argomenti)
OUTPUT
(assegnazione)
Funzioni: parametri e argomenti
def NomeFunzione(P1, P2...) :
…………….
return O1, O2,..... OM
Dichiarazione
PARAMETRI
R1= NomeFunzione(‘tt’, 24 ..)
Chiamata
ARGOMENTI
le variabili di assegnazione possono essere una oppure
tante quante sono i valori passati dall’istruzione return. Se
il numero è uguale, allora alle variabili sono assegnati i
diversi valori secondo una logica posizionale. Altrimenti
alla variabile di assegnazione è assegnata una tupla
contenente la sequenza dei risultati.
Argomenti assegnati
per posizione
Funzioni: parametri predefiniti e argomenti chiave
def NomeFunzione(P1, P2, P3=25, P4=’Italia’ ) :
………..
return O1, O2,..... OM
Dichiarazione
R1= NomeFunzione(‘tt’, 24, P3=60)
Chiamata
In fase di chiamata non è
necessario passare gli argomenti
corrispondenti ai parametri
predefiniti. In caso di assenza di
argomento essi assumono il
valore di default. Si può chiamare
una funzione modificando il valore
di uno o più parametri predefiniti
Funzioni: argomenti a lunghezza variabile
def NomeFunz.(*L) :
……..
Dichiarazione
R1= NomeFunz.(10,20)
Chiamata
R1= NomeFunz.(10,20,30)
R1= NomeFunz.(10,20,......123)
def NomeFunz.(**D) :
……..
Dichiarazione
R1= NomeFunz.(A=10)
Chiamata
R1= NomeFunz.(A=10,B=20)
LEZIONE 1..
www.fordatascientist.org
B00-PyBase
B53-Custom-Function
Funzioni ricorsive
E’ possibile scrivere la chiamata di una funzione all’interno di se stessa
def Indietro(N):
if N == 0: return
print(N)
Indietro(N-1)
Questa funzione chiama
se stessa con un
argomento
decrementato
progressivamente di
uno
def Fattoriale(n):
if n == 0:
#print('n è uguale a 0')
return 1
else:
R=n * Fattoriale(n-1)
#print(n,R)
return R
Funzione
call 1
call 2
call n
return 2
return 1
return n
Questa funzione chiama recorsivamente se
stessa fino a che N è uguale a zero. Quindi
assegna ricorsivamente il valore R alla
chiamante
PYTHON BASE
Funzioni temporali
LEZIONE 1..
www.fordatascientist.org
B00-PyBase
B71-DateTime
PYTHON BASE
File di input
LEZIONE 1..
www.fordatascientist.org
B00-PyBase
B60-FileInput
CONTATTI TELEFONO
051 22 35 20
EMAIL
WORKSHOP@VICEM.IT
def returnparametri
argomenti posizionali *list
argomenti di parola
chiave
**dict
datetime.datetime
pandas.Timestamp
istanti temporali
.is_year_end
pandas.Period .freq .period_range
periodi

More Related Content

PDF
08 - Programmazione: Passaggio valori tra funzioni per riferimenti
PDF
Lezione 5 (7 marzo 2012)
PDF
Esercitazione 1 (27 febbraio 2012)
PDF
16 - Programmazione: Gestione memoria
PDF
10 - Programmazione: Tipi di dato strutturati
PDF
15 - Programmazione: Algoritmi
PDF
05 - Programmazione: Funzioni
PDF
03 - Programmazione: Istruzioni C++
08 - Programmazione: Passaggio valori tra funzioni per riferimenti
Lezione 5 (7 marzo 2012)
Esercitazione 1 (27 febbraio 2012)
16 - Programmazione: Gestione memoria
10 - Programmazione: Tipi di dato strutturati
15 - Programmazione: Algoritmi
05 - Programmazione: Funzioni
03 - Programmazione: Istruzioni C++

What's hot (12)

PDF
Python - Primi passi
PDF
Flow chart
PDF
07 - Programmazione: Tipi di base e conversioni
PDF
Algoritmi e Programmazione Avanzata - Ordinamento e ricorsione
PDF
Algoritmi e Programmazione Avanzata - Esercizi propedeutici
PDF
11 - Programmazione: Tipi di dato strutturati pt. 2
PPTX
Algoritmi
PDF
12 - Programmazione: Array dinamici e puntatori
PPT
Riepilogo Java C/C++
PDF
Algoritmi E Strutture Dati Pile
PDF
Let's give it a GO!
PDF
Presentazione corretta algoritmi
Python - Primi passi
Flow chart
07 - Programmazione: Tipi di base e conversioni
Algoritmi e Programmazione Avanzata - Ordinamento e ricorsione
Algoritmi e Programmazione Avanzata - Esercizi propedeutici
11 - Programmazione: Tipi di dato strutturati pt. 2
Algoritmi
12 - Programmazione: Array dinamici e puntatori
Riepilogo Java C/C++
Algoritmi E Strutture Dati Pile
Let's give it a GO!
Presentazione corretta algoritmi
Ad

Viewers also liked (12)

PDF
Numpy + Pandas: Corso Python avanzato - ForDataScientist 01
PDF
Python base lezione 3
PDF
Python base lezione 2
PDF
Web base - SVG
PDF
ForDataScientist - Python advanced data
PDF
WEB BASE - Una visione d'insieme delle tecnologie web
PDF
Web base - CSS e selettori
PDF
Python base lezione 5
PDF
Web base - Javascript (Node.js): Elementi di base
PDF
Web base - HTML
PDF
Python base lezione1
PDF
ForDataScientist - Python matplotlib
Numpy + Pandas: Corso Python avanzato - ForDataScientist 01
Python base lezione 3
Python base lezione 2
Web base - SVG
ForDataScientist - Python advanced data
WEB BASE - Una visione d'insieme delle tecnologie web
Web base - CSS e selettori
Python base lezione 5
Web base - Javascript (Node.js): Elementi di base
Web base - HTML
Python base lezione1
ForDataScientist - Python matplotlib
Ad

More from Annalisa Vignoli (8)

PDF
Presentazione Corsi FDS
PPTX
Presentazione Ulisse - Rame
PPTX
Presentazione Ulisse - Acciaio
PDF
Fordatascientist - Tecnologie Web base
PDF
Fordascientist - Python reportlab
PDF
ForDataScientist - Python base parte2
PDF
ForDataScientist - Python base parte1
PDF
abstract_tesi
Presentazione Corsi FDS
Presentazione Ulisse - Rame
Presentazione Ulisse - Acciaio
Fordatascientist - Tecnologie Web base
Fordascientist - Python reportlab
ForDataScientist - Python base parte2
ForDataScientist - Python base parte1
abstract_tesi

Python base lezione 4