Introduzione a Python. Matteo Pradella Paolo Costa Matteo Migliavacca
|
|
- Albina Ippolito
- 7 anni fa
- Visualizzazioni
Transcript
1 Introduzione a Python Matteo Pradella Paolo Costa Matteo Migliavacca
2 Python sta per Pitone? No. Il nome deriva da Monty Python's Flying Circus (gruppo di comici inglese) Show BBC ma anche film: ricordiamo tra gli altri Brian di Nazareth, Il Senso della Vita, E ora qualcosa di completamente diverso... Guido van Rossum (padre di Python) e` un fan... 2
3 Dove trovare informazioni Sito ufficiale del linguaggio: interprete linux / win / MacOS (ultima versione 2.5), IDE per Win, tutorial, reference, Dive into Python (free book molto completo) "How to Think Like a Computer Scientist with Python (più introduttivo) Google -> Python 3
4 Un linguaggio interpretato Python, a differenza di C/C++, e` interpretato (anche se poi molte implementazioni lo compilano per motivi di efficienza): si puo` interagire con una macchina virtuale Python in maniera interattiva Prompt: >>> # questo e` un commento (come // in C++) Es. >>> >>> 10 / 3 # divisione intera 3 4
5 Definizione variabili >>> pippo = 7 Abbiamo creato una variabile pippo, di tipo intero, contenente il valore 7 >>> pippo = 5.5 Pippo e` divenuta una variabile reale... >>> a = b = c = 0 sia a che b che c assumono il valore 0 5
6 Stringhe Le stringhe si possono scrivere in vari modi: 'questi sono' 'un po\' di caratteri', oppure, se preferisco: "un po' di caratteri" 'Mi guardo` e mi disse: "vattene!" Allora gli sparai...' '\n' va a capo come in C 6
7 Stringhe:concatenazione, ripetizione >>> ehm = "aiuto! " >>> Al fuoco! + ehm Al fuoco! aiuto! >>> ehm * 7 'aiuto! aiuto! aiuto! aiuto! aiuto! aiuto! aiuto! ' >>> ehm * 0 ' ' # stringa vuota 7
8 Stringhe e indici In Python le stringhe sono sequenze: si puo` accedere ad elementi tramite indici >>> "Questa lezione mi sta annoiando parecchio"[4] 't' >>> "Preferivo stare a letto"[0:9] # ecco uno slice 'Preferivo' N.B. 9 escluso nello slice 8
9 Non cambiar la stringa Le stringhe non sono modificabili >>> casa = "voglio andare a casa"; casa[4] = 'i' Traceback (most recent call last): File "<stdin>", line 1, in? TypeError: object doesn't support item assignment Pero` posso copiarle: >>> casetta = casa[0:5] + 'a' + casa[6:] 9
10 Ancora slice >>> parola = "casa" >>> parola[:2] 'ca' >>> parola[2:] 'sa' >>> parola[:] 'casa' # N.B. e` una copia >>> parola[-2] # anche all'indietro! 's' >>> len(parola) # lunghezza di una sequenza 4 c a s a
11 Liste es. Fondamentali e molto usate in Python Sono sequenze, come le stringhe (ergo: indici, slice, len) Pero` sono modificabili Assumono anche il ruolo che e` degli array in altri linguaggi >>> lista = ["una lista", 4, 6.2] >>> len(lista) 3 11
12 append un classico delle liste: si aggiunge elemento in coda con append >>> lista.append(3) >>> lista ['una lista', 4, 6, 2, 3] 12
13 E ora i cicli... Partiamo col ciclo while un semplice esempio: i numeri di Fibonacci a, b = 0, 1 # assegnamento con tupla (detto multiplo)! while b < 10: print b, # "," serve ad evitare \n finale a, b = b, a+b come delimito il blocco di istruzioni? (in C/C++ si usa {...}) 13
14 Stile di indentazione In Python, a differenza della stragrande maggioranza degli altri linguaggi, il corpo del while (un blocco in generale) e` delimitato per mezzo della indentazione! istr1 istr2 istr3 istr4 istr5 blocco 2 blocco 1 { istr1; // in C istr2; { istr3; istr4; istr5; }} (posso usare spazi o tab, basta che siano lo stesso numero) 14
15 if La forma piu` generale: if cond1 : # cond1 vera elif cond2 : # cond2 vera elif cond3 : # cond3 vera... else : # nemmeno una vera! 15
16 Ora il for Il for, a differenza del C, itera su sequenze (es. stringhe o liste) in pratica: for i in seq: # fai qualcosa con i Per esempio: >>> for i in ['Ma questa', 'e`', 1, 'lista?'] :... print i, Ma questa e` 1 lista? 16
17 range() range permette di iterare su una sequenza di numeri (senza doverli scrivere tutti) >>> range(10) [0, 1, 2, 3, 4, 5, 6, 7, 8, 9] Come al solito, estremo superiore escluso. 17
18 Costruttori sofisticati di liste Comodi! Assomigliano molto alla notazione insiemistica, per es. un analogo di {(x,y) x A, y B, x y} si puo` scrivere come [(x,y) for x in A for y in B if x!= y] A proposito, (x,y) e` un esempio di tupla (come in matematica) in Python e` una sequenza immutabile si puo` usare come alternativa piu` efficiente alle liste, se non si devono modificare dati Attenzione! E` comunque una lista, non un insieme (e` un insieme totalmente ordinato che ammette piu` occorrenze dello stesso elemento)... 18
19 Le funzioni Possiamo definire funzioni con def: def f(n) : """Be' se proprio voglio qui ci metto la stringa di documentazione (cosa fa f?)""" if n == 0: return 1 else: return n*f(n-1) 19
20 Scope (o campo d'azione) statico Capisco dalla struttura statica del programma dove sono definiti i nomi ad es. di variabile che sto usando >>> def f(): x = 5 g() >>> def g(): print x >>> f() Traceback (most recent call last): File "<pyshell#7>", line 1, in -toplevelg() File "<pyshell#6>", line 2, in g print x NameError: global name 'x' is not defined 20
21 Funzioni: argomenti di default def incipitizza(seq, incipit = 'banale'): seq[0] = incipit return seq >>> a = [1,2,3] >>> incipitizza(a) ['banale', 2, 3] >>> incipitizza(a,1)... 21
22 Argomenti con parole chiave def parrot(voltage, state='a stiff', action='voom', type='norwegian Blue'): print "-- This parrot wouldn't", action, print "if you put", voltage, "Volts through it." print "-- Lovely plumage, the", type print "-- It's", state, "!" Si puo` chiamare in questi modi: parrot(1000) parrot(action = 'VOOOOOM', voltage = ) parrot('a thousand', state = 'pushing up the daisies') parrot('a million', 'bereft of life', 'jump') In questo modo nell invocazione della funzione posso alternare indifferentemente parametri attuali e parametri di default (purchè il risultato finale sia consistente) 22
23 I dizionari Sono anche chiamati memorie associative o array associativi A differenza delle sequenze, gli indici non sono interi bensi`chiavi (es. stringhe) Sintassi: {chiave1 : val1, chiave2 : val2,...} il metodo keys() restituisce la lista delle chiavi di un dizionario 23
24 dizionari: qualche esempio... >>> tel = {'jack': 4098, 'sape': 4139} >>> tel['guido'] = 4127 >>> tel {'sape': 4139, 'guido': 4127, 'jack': 4098} >>> tel['jack'] 4098 >>> del tel['sape'] >>> tel['irv'] = 4127 >>> tel {'guido': 4127, 'irv': 4127, 'jack': 4098} >>> tel.keys() ['guido', 'irv', 'jack'] >>> tel.has_key('guido') True 24
25 dir() dir() applicato a qualcosa mi dice quali nomi sono definiti in questo qualcosa (un po' vago...) esempio: >>> a = [1, 2, 3] >>> dir(a)[' add ', ' class ', ' contains ', ' delattr ', ' delitem ', ' delslice ', ' doc ', ' eq ', ' ge ', ' getattribute ', ' getitem ', ' getslice ', ' gt ', ' hash ', ' iadd ', ' imul ', ' init ', ' iter ', ' le ', ' len ', ' lt ', ' mul ', ' ne ', ' new ', ' reduce ', ' reduce_ex ', ' repr ', ' rmul ', ' setattr ', ' setitem ', ' setslice ', ' str ', 'append', 'count', 'extend', 'index', 'insert', 'pop', 'remove', 'reverse', 'sort'] NB: la notazione qualcosa (dove sono due caratteri di sottolineatura) e` abbastanza classica in Python: sono metodi ed attributi con ruoli particolari vedremo meglio nella parte sulla OO 25
26 Classi e programmazione OO Python da 2.2 introduce le cosiddette nuove classi noi vedremo esclusivamente queste -- le altre rimangono per ragioni di compatibilità NB: non guardate il tutorial (anche ultima versione) perchè non è aggiornato. Consultate il What s new in
27 Definizione di classe class NomeClasse(object) : a = 5 def init (self, altro) : il progenitore di ogni classe è object a = foofoo x = NomeClasse(a) costruttore self è sempre il primo argomento di un metodo: si riferisce all'oggetto stesso (self, appunto!) attributi sono modificabili dinamicamente e accessibili con la notazione puntata (es. oggetto.attributo) 27
28 elementi "privati" Tutto e` pubblico, in genere (invece ad es. in C++ devo definire la parte visibile per mezzo di public:) un modo per "nascondere" metodi e attributi, e` dare loro un nome che inizia con un doppio '_' per es. pippo l'attributo/metodo creato in questo caso ha il nome effettivo _nomedellaclasse pippo, piuttosto difficile da usare per errore... 28
29 Ereditarieta` >>> class A(object): def f(self): print "Padre" >>> class B(A): def f(self): print "Figlio" >>> x = A() >>> y = B() >>> x.f() Padre >>> y.f() Figlio Supporta l ereditarieta multipla 29
30 Overload Non posso fare overloading (se ho piu metodi con numero diverso di parametri viene chiamato quello che ho definito per ultimo) >>> class A(object): def f(self): print metodo senza parametri" def f(self, n): print metodo con parametri" >>> x = A() >>> x.f() Traceback (most recent call last): File "<pyshell#7>", line 1, in -toplevelx.f() TypeError: f() takes exactly 2 arguments (1 given) >>> x.f(2) 30
31 Python Type System E un linguaggio tipizzato Non fa static type checking (ma fa dynamic type checking: gli errori di tipo vengono rilevati, ma a runtime) Il tipo delle variabili non e dichiarato >>> x = 0 # x bound to an integer object >>> x = "Hello" # now it's a string >>> x = [1, 2, 3] # and now it's a list 31
32 Python Type System Le funzioni sono first class object Non c e` nessuna differenza tra variabili che contengono valori e quelle che contengono funzioni (callable/non callable) >>> def f(): >>> return 66 >>> x = f >>> x() 66 Posso anche passare le funzioni come parametri >>> def f(x): x() >>> def a(): print "Io sono a" >>> def b(): print "Io sono b" >>> f(a) Io sono a >>> f(b) 32
33 Dynamic Type Checking Ottengo un errore di tipo quando python non trova l attributo a cui sto accedendo cioe : invoco un metodo non definito dell oggetto leggo un campo non definito dell oggetto 33
34 Dynamic Type Checking class libro(object): def init (self,contenuto): self.contenuto = contenuto contenuto = "Nel mezzo del cammin di nostra vita" def read(self): return self.contenuto def stampacontenuto(l): print l.read() x = libro("nel mezzo del cammin di nostra vita") y = "Questo non e' un libro" import random if random.random() < 0.5: stampacontenuto(y) else: stampacontenuto(x) Questo programma ha un errore di tipo ma viene rilevato nel 50% dei casi 34
35 Dynamic Type Checking In questo caso ottengo un eccezione Traceback (most recent call last): File "<pyshell#215>", line 2, in -toplevelstampacontenuto(y) File "<pyshell#206>", line 2, in stampacontenuto print l.read() AttributeError: 'str' object has no attribute 'read' 35
36 Dynamic Type Checking MA: class P(object): valore = 5 >>> x = P() >>> x.valore = 10 >>> x.valore 10 >>> x.valoree = 20 Nessuna eccezione!! => in python se provo ad assegnare (binding) un attributo che non esiste python lo crea al momento! 36
37 Dynamic Type Checking Quindi in questo momento la variabile x e una reference a un istanza di P con IN PIU un attributo valoree >>> type(x) <class ' main.p'> >>> dir(x) [' class ', ' delattr ', ' dict ', ' doc ', ' getattribute ', ' hash ', ' init ', ' module ', ' new ', ' reduce ', ' reduce_ex ', ' repr ', ' setattr ', ' str ', ' weakref ', 'valore', 'valoree'] 37
38 Dynamic Type Checking Risoluzione degli attributi (es x.attr) prima cerco nell istanza x poi cerco nella classe di x infine cerco nelle classi padre (ereditarieta ) 38
39 Tutto dinamico... Oltre le istanze posso modificare dinamicamente anche la classe Tutte le istanze da quel momento in poi hanno i nuovi attributi (ovvio se pensiamo alla procedura di risoluzione degli attributi) class p(object) : def init (self) : self.a = 5 def g(t,n) : t.a = n def f(t) : # da aggiungere print t.a >>> x = p() >>> p.f = f # lo aggiungiamo >>> x.f() 5 >>> p.g = g >>> x.g(3) >>>x.f() 3 39
40 Assegnamento - 1 In Python l accesso agli oggetti avviene tramite reference (analogo di quanto avviene in JAVA con le classi) Non esiste dichiarazione delle varibili: vengono istanziate quando vi si assegna un valore per la prima volta Non si può utilizzare una variabile prima che sia stata inizializzata 40
41 Assegnamento - 2 Quando si esegue un assegnamento in realtà viene copiata la reference non l oggetto >>> a = [1,2,3] >>> b = a >>> id(a) # id(var) restituisce l'indirizzo (l-value) di var >>> id(b) Si crea un alias: modificando a modifico anche b 41
42 Assegnamento - 3 a = [1, 2, 3] a b = a a b a.append(4) a b
43 Assegnamento - 4 In Python gli oggetti si dividono in: Oggetti mutabili il cui valore può essere modificato (liste, dizionari, classi) >>> a = [1, 2, 3, 4] >>> id(a) >>> a[0] = 1 >>> id(a) Oggetti immutabili il cui valore non può essere modificato senza creare un nuovo oggetto >>> a = 5 >>> id(a) Viene creato un nuovo oggetto e ad a viene assegnata la reference del nuovo oggetto >>> a = 3 (nuovo binding) >>> id(a)
44 Mutabili e Immutabili Tipo Mutabile? Numeri No Stringhe No Liste Si Dizionari Si 44
45 Assegnamento - 5 a = 1 a 1 a b = a a = a+1 b a b new int object created by add operator (1+1) old reference deleted by assignment (a=...) 45
46 Passaggio di parametri In Python il passaggio di parametri avviene per indirizzo: i parametri formali diventano degli alias dei parametri attuali >>> a = [1,2] >>> def swap(x):... temp = x[0]... x[0] = x[1]... x[1] = temp... >>> swap(a) >>> print a [2, 1] La funzione ha modificato l oggetto passato come parametro 46
47 Passaggio di parametri NB: se invece di modificare l oggetto la funzione esegue un assegnamento (ovvero crea un nuovo binding), si interrompe il legame tra parametro formale e attuale che fanno ora riferimento a due celle distinte >>> def f(x):... x = 1 # creo un nuovo binding. Perdo il collegamento con l'oggetto passato per parametro... >>> a = 1000 >>> f(a) >>> print a # stampa 1000 Le modifiche non sono visibile al chiamante 47
48 Python e oltre Esistono numerose caratteristiche di Python che non sono state affrontate: Supporto per il multi-thread (Java style) Servizi del sistema operativo Protocolli di rete tcp, http, smtp, Reflection (simile a Java) Parsing XML Debugger PyUnit (la versione Python di JUnit) Librerie grafiche 2D (Tkinter, PyQt) e anche 3D (SDL) 48
49 Esempio: invio di una mail import sys, smtplib fromaddr = raw_input("from: ") toaddrs = raw_input("to: ").split(, ) msg = while 1: line = sys.stdin.readline() if not line: break msg = msg + line server = smtplib.smtp( localhost ) server.sendmail(fromaddr, toaddrs, msg) 49
50 Esercizio: 4/04/2005 Indicare l'output prodotto da questo programma Python, motivando la semantica delle istruzioni della funzione f. Risposte non motivate non verranno prese in considerazione. def f(a, b, c, d): a.append(5) b = [3, 5] c[0] = 9 d = 4 a = [0] b = [1] c = [2] d = 3 f(a,b,c,d) print a, b, c, d 50
51 Soluzione Il programma stampa [0, 5] [1] [9] 3 Le istruzioni: aggiunge un elemento alla lista del chiamante, modificandola. L assegnamento annulla il binding con la lista passata come parametro e ne effettua uno nuovo, lasciando quindi inalterato l oggetto originale. L assegnamento modifica la lista del chiamante, cambiando il binding di un suo elemento. L assegnamento annulla il binding con l intero passato come parametro e ne effettua uno nuovo, lasciando quindi inalterato l oggetto originale. 51
52 Esercizio: 4/04/2005 Definire nel linguaggio Python la funzione map(f, lis) che, a partire da una funzione f() (che si suppone abbia un argomento) e da una lista seq = [e1... en] restituisca la lista [f(e1)...f(en)]. 52
53 Soluzione def map(f, lis): s=[] for i in lis: s.append(f(i)) return s 53
54 Esercizio: 4/04/2005 Definire inoltre una funzione accumulate(f, lis, zero) che a partire da una funzione f() (che si suppone abbia due argomenti) e da una lista seq = [e1 e2... en] e dal valore zero restituisca il valore f(...f(f(zero, e1),e2)..., en). 54
55 Soluzione def accumulate(f, lis, zero): res = zero for i in lis: res = f(res,i) return res 55
56 Esercizio: 4/04/2005 Facendo uso della funzione add (definita qui sotto), della funzione ithodd(i) (pure definita qui sotto, restituisce l i-simo numero dispari), delle funzioni map e accumulate, ed eventualmente di altri noti costrutti del linguaggio Python, definire la funziona squarebysum(n) che calcola il quadrato del numero n, assunto intero positivo, come somma dei primi n numeri dispari (Es. 5 => [ ] => [ ] => => 25). def ithodd(i): return 2*i+1 56
57 Soluzione def add(a,b): return a+b def squarebysum(n): return accumulate(add, map(ithodd,range(n)),0) 57
Introduzione a Python. Matteo Pradella Paolo Costa Matteo Migliavacca
Introduzione a Python Matteo Pradella Paolo Costa Matteo Migliavacca Python sta per Pitone? No. Il nome deriva da Monty Python's Flying Circus (gruppo di comici inglese) Show BBC ma anche film: ricordiamo
Programmazione in Python. Moreno Marzolla
Programmazione in Python Moreno Marzolla http://www.moreno.marzolla.name/ Copyright 2011, Moreno Marzolla (http://www.moreno.marzolla.name/teaching/labinf2011/) This work is licensed under the Creative
Programmazione Orientata agli Oggetti e Scripting in Python
DIEE - Università degli Studi di Cagliari Programmazione Orientata agli Oggetti e Scripting in Python Paradigma ad Oggetti - 2 Alessandro Orro DIEE Univ. di Cagliari 1 ereditarietà: metodi Il meccanismo
Liste, dizionari e tuple
Liste, dizionari e tuple Andrea Passerini passerini@disi.unitn.it Informatica Liste Descrizione Una lista è una sequenza di oggetti qualunque (anche di tipo diverso, anche altre liste) >>> l = ["abc",
Laboratorio di Python (con Linux)
8 a lezione Università di Bologna 2, 4 maggio 2012 Sommario 1 2 3 Diversi Python 2.6 vs 2.7 v.s 3.x La versione di Python installata sulle macchine del laboratorio è la 2.6 (per l esattezza 2.6.6 ). Versioni
Essendo una sequenza, condivide le operazioni su sequenza viste per le stringhe
Liste Descrizione Una lista è una sequenza di oggetti qualunque (anche di tipo diverso, anche altre liste) = ["abc", 2, [1,2]] Essendo una sequenza, condivide le operazioni su sequenza viste per le stringhe
Il linguaggio Python
Il linguaggio Python Capitolo 2 Variabili, Espressioni e Comandi Prof. Mauro Gaspari: gaspari@cs.unibo.it Il Linguaggio Python Python e' un linguaggio imperativo con alcune caratteristiche funzionali.
Laboratorio di Python
Istruzione di condizione, Input da tastiera, Università di Bologna 6 e 8 marzo 2013 Sommario 1 Tipi di errore e Debugging 2 3 4 Outline Tipi di errore e Debugging 1 Tipi di errore e Debugging 2 3 4 Esercizio
Strutture blocco. Indentazione e istruzione blocco
Strutture blocco Indentazione e istruzione blocco In Python il blocco di istruzioni è definito tramite il meccanismo dell indentazione. L indentazione consiste nell inserire un certo numero di spazi (o
14 - Metodi e Costruttori
14 - Metodi e Costruttori Programmazione e analisi di dati Modulo A: Programmazione in Java Paolo Milazzo Dipartimento di Informatica, Università di Pisa http://www.di.unipi.it/ milazzo milazzo di.unipi.it
Programmazione in Python per la bioinformatica
per la bioinformatica University of Verona Sommario La struttura dati Lista Lista Come si rappresenta una lista in python Reminder: Lista collezione ordinata di elementi L = a 0, a 1,, a n 1 La variabile
Laboratorio di Python
, Input da tastiera, Iterazione incondizionata 7 marzo 2014 Sommario 1 2 3 Outline 1 2 3 Definizione di funzione import modulo Si importa il modulo specificato def nome_f(par 1,, par n ) : Si definiscono
Programmazione 2. Introduzione al corso
Programmazione 2 Introduzione al corso Informazioni generali Sito del corso http://matematica.unipv.it/gualandi/programmazione2/ Orario lezioni: Martedi 9h00/11h00 Aula C8 o Lab. Mate Giovedi 14h00/15h00
OOP: Object Oriented Programming
OOP: Object Oriented Programming Riferimenti per questa parte: 1. Capitoli 7 e 8 del testo di riferimento 2. https://docs.python.org/3.6/tutorial/classes.html OOP: Idea Principale L idea principale della
7 - Programmazione procedurale: Dichiarazione e chiamata di metodi ausiliari
7 - Programmazione procedurale: Dichiarazione e chiamata di metodi ausiliari Programmazione e analisi di dati Modulo A: Programmazione in Java Paolo Milazzo Dipartimento di Informatica, Università di Pisa
Per visualizzare il valore di tutte le variabili d ambiente si usa il comando env
Tipi di Shell sh Bourne shell csh C shell ksh Korn shell bash Bourne Again (Bash) shell tcsh TENEX C shell zsh Z shell rc rc shell es es shell à csh e bash sono le più comuni. Per cambiare il tipo di shell
Tipi di dato strutturati: Array
Tipi di dato strutturati: Array I dati visti finora sono: numeri (interi o razionali), booleani le stringhe (sequenze di caratteri) ma i dati manipolati nelle applicazioni reali sono spesso complessi (o
9 - Array. Programmazione e analisi di dati Modulo A: Programmazione in Java. Paolo Milazzo
9 - Array Programmazione e analisi di dati Modulo A: Programmazione in Java Paolo Milazzo Dipartimento di Informatica, Università di Pisa http://www.di.unipi.it/ milazzo milazzo di.unipi.it Corso di Laurea
Rudimenti di Python. senza rodimenti di Python
Rudimenti di Python senza rodimenti di Python Contatti _ Enrico Marino _ Federico Spini _ mail: _ (marino spini)@dia.uniroma3.it! _ sito: _ dia.uniroma3.it/~(marino spini)/python! Riferimenti _ sito ufficiale:
6 - Blocchi e cicli. Programmazione e analisi di dati Modulo A: Programmazione in Java. Paolo Milazzo
6 - Blocchi e cicli Programmazione e analisi di dati Modulo A: Programmazione in Java Paolo Milazzo Dipartimento di Informatica, Università di Pisa http://pages.di.unipi.it/milazzo milazzo di.unipi.it
Laboratorio di Python
Laboratorio di Python Matrici con Liste Lab09 5 Aprile 2017 Outline Correzione esercizi per oggi Matrici Teoria Esercizi Esercizi per casa Esercizio 1 per casa Scrivere una funzione che verifica se una
Corso di Linguaggi di Programmazione
Corso di Linguaggi di Programmazione Lezione 19 Alberto Ceselli alberto.ceselli@unimi.it Dipartimento di Informatica Università degli Studi di Milano 14 Maggio 2013 Idea Programma = Algoritmi + Strutture
Lezione 5: Controllo del flusso e costrutti avanzati
Lezione 5: Controllo del flusso e costrutti avanzati Laboratorio di Elementi di Architettura e Sistemi Operativi 20 Marzo 2013 Parte 1: Il valore di uscita di un processo Il valore di uscita di un processo
Fondamenti di Programmazione
Fondamenti di Programmazione Capitolo 12 Polimorfismo e ereditarietà Prof. Mauro Gaspari: gaspari@cs.unibo.it Una classe tempo class Time: def init (self,hours=0,minutes=0,seconds=0): self.hours = hours
C: panoramica. Violetta Lonati
C: panoramica Violetta Lonati Università degli studi di Milano Dipartimento di Scienze dell Informazione Laboratorio di algoritmi e strutture dati Corso di laurea in Informatica AA 2009/2010 Violetta Lonati
Esempio su strutture dati dinamiche: ArrayList
Esempio su strutture dati dinamiche: ArrayList 1 ArrayList Abbiamo detto che gli array non possono cambiare la propria dimensione: il numero di elementi contenuti viene stabilito al momento della creazione
Programmazione orientata agli oggetti: le classi
Programmazione orientata agli oggetti: le classi Oggetti e tipi di dati La programmazione che abbiamo visto finora agisce su variabili che appartengono a tipi di dati predefiniti: interi, floating point,
Logica booleana, Costrutto IF
Logica booleana, Costrutto IF Informatica@SEFA 207/208 - Lezione 4 Massimo Lauria http://massimolauria.net/courses/infosefa207/ Mercoledì, 4 Ottobre 207 La logica booleana 2
Avviate l interprete Python selezionandolo dal menu dei programmi. Una volta avviato, l interprete presenta un cursore in cui inserire comandi
Introduzione al Python Caratteristiche procedurale si specifica la procedura da eseguire sui dati strutturato concetto di visibililtà delle variabili orientato agli oggetti permette di programmare con
Raccolta di tutorial Python #1: basi e Tkinter dal sito francescomilanese.com SOMMARIO
Prima parte: le basi di Python 1. Introduzione. Cosa ci serve, cosa è richiesto, cosa faremo. Note sull'indentazione 1 Introduzione 1 Scrittura degli script: l'idle 2 Importare moduli in uno script 3 I
Laboratorio di Programmazione Lezione 2. Cristian Del Fabbro
Laboratorio di Programmazione Lezione 2 Cristian Del Fabbro Prossima lezione GIOVEDÌ 29 OTTOBRE 14:00 Input da tastiera package input; import java.io.*; public class Input { public static void main(string[]
Corso di Linguaggi di Programmazione
Corso di Linguaggi di Programmazione Lezione 5 Alberto Ceselli alberto.ceselli@unimi.it Università degli Studi di Milano 12 Marzo 2013 Le funzioni sono oggetti di prima classe in Scheme In Scheme le funzioni
Introduzione al linguaggio C Puntatori
Introduzione al linguaggio C Puntatori Violetta Lonati Università degli studi di Milano Dipartimento di Informatica Laboratorio di algoritmi e strutture dati Corso di laurea in Informatica 19 ottobre 2016
Programmazione a Oggetti Lezione 7. Il linguaggio Java: aspetti generali
Programmazione a Oggetti Lezione 7 Il linguaggio Java: aspetti generali Sommario Obiettivi di JAVA Portabilità: produrre codice eseguibile su più piattaforme (JVM) Affidabilità: Evitare il più possibile
FUNZIONI COME COMPONENTI SW FUNZIONI COME COMPONENTI SW FUNZIONI MODELLO CLIENTE/SERVITORE
FUNZIONI Spesso può essere utile avere la possibilità di costruire nuove istruzioni che risolvano parti specifiche di un problema Una funzione permette di dare un nome a una espressione rendere tale espressione
Laboratorio di Python
Laboratorio di Python Alberi binari Lab15 12 Maggio 2017 Outline Correzione esercizi per oggi Alberi binari Teoria Esercizi Esercizi per casa Saluti Esercizio 1 per casa Scrivere una funzione palindroma(s)
Funzioni e moduli. Andrea Passerini Informatica. funzioni e moduli
Funzioni e moduli Andrea Passerini passerini@disi.unitn.it Informatica Funzioni nella programmazione Descrizione Una funzione è una sequenza di istruzioni cui viene dato un nome Questo permette di riutilizzare
Definizione di classi. Walter Didimo
Definizione di classi Walter Didimo Definizione di classi Fino ad ora abbiamo imparato a: creare oggetti da classi già pronte usare gli oggetti creati, invocando metodi la creazione e l uso di oggetti
LABORATORIO DI PROGRAMMAZIONE 2 Corso di laurea in matematica. Algoritmi ricorsivi
LABORATORIO DI PROGRAMMAZIONE 2 Corso di laurea in matematica Marco Lapegna Dipartimento di Matematica e Applicazioni Universita degli Studi di Napoli Federico II wpage.unina.it/lapegna Partiamo da un
Ingegneria degli Algoritmi (II parte pratica)
Ingegneria degli Algoritmi (II parte pratica) Correzione prova pratica Ing. Domenico Spera domenico.spera@students.uniroma2.eu Premessa Sono stati richiesti i seguenti task: Implementare la versione in-order
OCA JAVA 7 SE PROGRAMMER I DOCENTE: DOTT. FAUSTO DELL ANNO
CENTRO STUDI ULISSE Via Buccino, n. 22 - C.a.p. 84018 - Scafati (SA) Tel. Fax. 081.19970299-339.2365416-349.4152010 E-mail: info@centrostudiulisse.it - www.centrostudiulisse.it OCA JAVA 7 SE PROGRAMMER
Shell: variabili di sistema. Per visualizzare il valore di tutte le variabili d ambiente si usa il comando set
PATH Shell: variabili di sistema HOME USER PWD SHELL HOSTNAME HOSTTYPE Per visualizzare il valore di tutte le variabili d ambiente si usa il comando set Shell: variabili di sistema Per visualizzare il
Metodi Informatici per la Biologia
Metodi Informatici per la Biologia Esercitazione 8 1. Altri dettagli sulle funzioni Come ormai sapete bene, la forma generale di una funzione è: def nome_funzione(argomento1, argomento2, ): "documentazione"
Laboratorio 02. Programmazione - CdS Matematica. Mirko Polato 3 Novembre 2015
Laboratorio 02 Programmazione - CdS Matematica Mirko Polato 3 Novembre 2015 Contenitori Spesso è necessario utilizzare contenitori di oggetti. 2 of 26 Contenitori Spesso è necessario utilizzare contenitori
Introduzione al linguaggio Python
Introduzione al linguaggio Python Che c'entrano I serpenti? - Nulla, il nome deriva da Monty Python's Flying Circus (gruppo di comici inglese) - Show BBC ma anche film: ricordiamo tra gli altri Brian di
A. Lorenzi, A. Rizzi Java. Programmazione ad oggetti e applicazioni Android Istituto Italiano Edizioni Atlas
Classi e oggetti A. Lorenzi, A. Rizzi Java. Programmazione ad oggetti e applicazioni Android Istituto Italiano Edizioni Atlas Oggetti La programmazione orientata agli oggetti, OOP (Object-Oriented Programming),
19 - Eccezioni. Programmazione e analisi di dati Modulo A: Programmazione in Java. Paolo Milazzo
19 - Eccezioni Programmazione e analisi di dati Modulo A: Programmazione in Java Paolo Milazzo Dipartimento di Informatica, Università di Pisa http://www.di.unipi.it/ milazzo milazzo di.unipi.it Corso
Informatica 3. LEZIONE 2: Sintassi e semantica
Informatica 3 LEZIONE 2: Sintassi e semantica Modulo 1: Introduzione ai concetti di sintassi e semantica Modulo 2: Il concetto di binding Modulo 3: Variabili Modulo 4: Routine Convenzioni dei nomi Informatica
Linked Lists. Liste linkate (1) liste linkate ( stack, queues ), trees. Liste linkate come strutture
Linked Lists Liste linkate () La combinazione di class/struct e puntatori porta alla creazioni di interessanti Abstract Data Type liste linkate ( stack, queues ), trees Liste linkate come strutture struct
Laboratorio di Informatica
Laboratorio di Informatica Seconda lezione a Python Dottore Paolo Parisen Toldin - parisent@cs.unibo.it Dottoressa Sara Zuppiroli - sara.zuppiroli@unibo.it L'importanza di capire Perché non dobbiamo dichiarare
Il linguaggio C. Puntatori e dintorni
Il linguaggio C Puntatori e dintorni 1 Puntatori : idea di base In C è possibile conoscere e denotare l indirizzo della cella di memoria in cui è memorizzata una variabile (il puntatore) es : int a = 50;
Laboratorio di Python (con Linux)
Indeterminata,,,... Università di Bologna 14, 16 marzo 2012 Sommario 1 2 3 4 5 Modularità Quando si deve fare un programma complicato è meglio suddividerlo in più parti. Per ridurre la complessità (più
Concetti base programmazione. Antonio Gallo
Concetti base programmazione Antonio Gallo info@laboratoriolibero.com Programma Insieme di istruzioni: Strtturato Ad oggetti Strutturato Ha una struttura più lineare Basato sui concetti di sequenza, selezione,
OOP - Object Oriented Programming
OOP - Object Oriented Programming Python linguaggio versatile, supporta, sia programmazione procedurale/funzionale sia, programmazione a oggetti (in maniera non esclusiva) Programmazione orientata agli
BASI LINGUAGGIO. Programmazione Web 1
BASI LINGUAGGIO Programmazione Web 1 Commen0 Riga singola // This is a comment Riga mul8pla /* This is a sec8on of mul8line comments which will not be interpreted */ Programmazione Web 2 Istruzioni Un
Java il Corso Fondamentale
Java il Corso Fondamentale Imparare a Programmare APP per Android, applicativi per Server e Desktop, applet e molto altro. IlTuoCorso - Ermes srl Via E.De Amicis 57 20123 Milano Il corso Ciao! Se desideri
Statements: blocchi di istruzioni
Statements: blocchi di istruzioni Andrea Passerini passerini@disi.unitn.it Informatica Statements Descrizione Uno statement è un blocco di istruzioni semplici consistono di una singola riga. I tipi visti
Esercizi riassuntivi (Fondamenti di Informatica 2 Walter Didimo) Soluzioni
Esercizi riassuntivi (Fondamenti di Informatica 2 Walter Didimo) Soluzioni Esercizio 1 Dire quale è la complessità temporale del seguente metodo, espressa con notazione asintotica O(.) (con la migliore
Input/Output. Console e File.
Input/Output Console e File http://www.dia.uniroma3.it/~roselli/ roselli@dia.uniroma3.it Credits Materiale a cura del Prof. Franco Milicchio Introduzione Le istruzioni di stampa servono a rendere visibili
Informatica 3. Informatica 3. LEZIONE 2: Sintassi e semantica. Lezione 2- Modulo 1. Le componenti di un linguaggio di programmazione
Informatica 3 Informatica 3 LEZIONE 2: Sintassi e semantica Lezione 2- Modulo 1 Modulo 1: Introduzione ai concetti di sintassi e semantica Modulo 2: Il concetto di binding Modulo 3: Variabili Modulo 4:
Laboratorio di Python
Laboratorio di Python Code Lab13 28 Aprile 2017 Outline Correzione esercizi per oggi Code Teoria Esercizi Esercizi per casa Esercizio 1 per casa Scrivere una funzione che determina se uno studente può
Funzioni in C. Funzioni. Strategie di programmazione. Funzioni in C. Come riusare il codice? (2/3) Come riusare il codice? (1/3)
Funzioni Il concetto di funzione Parametri formali e attuali Il valore di ritorno Definizione e chiamata di funzioni Passaggio dei parametri Corpo della funzione 2 Strategie di programmazione Riuso di
Funzioni, Stack e Visibilità delle Variabili in C
Funzioni, Stack e Visibilità delle Variabili in C Programmazione I e Laboratorio Corso di Laurea in Informatica A.A. 2016/2017 Calendario delle lezioni Lez. 1 Lez. 2 Lez. 3 Lez. 4 Lez. 5 Lez. 6 Lez. 7
Indice. Prefazione. 3 Oggetti e Java 53
Prefazione xv 1 Architettura dei calcolatori 1 1.1 Calcolatori e applicazioni 1 1.1.1 Alcuni esempi di applicazioni 3 1.1.2 Applicazioni e interfacce 4 1.2 Architettura dei calcolatori 7 1.2.1 Hardware
Variabili e Metodi di classe Interfacce e Package Gestione di File in Java
Fondamenti di Informatica Variabili e Metodi di classe Interfacce e Package Gestione di File in Java Fondamenti di Informatica - D. Talia - UNICAL 1 Variabili di classe: Static Una variabile di classe
I Tipi di Dato Astratto
I Tipi di Dato Astratto Sommario Cosa sono le Strutture Dati Astratte? Le strutture dati Le operazioni Come scegliere fra varie implementazioni? Quale è la questione? Come organizzare (strutturare) i dati
Indice PARTE A. Prefazione Gli Autori Ringraziamenti dell Editore La storia del C. Capitolo 1 Computer 1. Capitolo 2 Sistemi operativi 21 XVII XXIX
Indice Prefazione Gli Autori Ringraziamenti dell Editore La storia del C XVII XXIX XXXI XXXIII PARTE A Capitolo 1 Computer 1 1.1 Hardware e software 2 1.2 Processore 3 1.3 Memorie 5 1.4 Periferiche di
Funzioni costruttore e istanza di un'oggetto
Funzioni costruttore e istanza di un'oggetto Solitamente si dice che un oggetto è un'istanza di una classe. In Javascript non esistono classi ma funzioni costruttore che sono abbastanza simili. Per instanziare
Esempio su strutture dati dinamiche: ArrayList
Esempio su strutture dati dinamiche: ArrayList Fondamenti di Informatica L-B 1 ArrayList Abbiamo detto che gli array non possono cambiare la propria dimensione: il numero di elementi contenuti viene stabilito
Metodi. Un metodo è una porzione di codice a cui si associa un nome. Un istruzione eseguita da un metodo può essere:
Metodi Un metodo è una porzione di codice a cui si associa un nome. Un istruzione eseguita da un metodo può essere: invocazione: esecuzione di un metodo assegnamento: cambia lo stato di un campo ripetizione:
Python. Valerio Perticone
Python Valerio Perticone Python Python è un linguaggio di programmazione molto semplice e conciso Ha il vantaggio di essere semplice da imparare e di poter essere eseguito su diversi sistemi operativi
Fondamenti di Informatica 1. Prof. B.Buttarazzi A.A. 2010/2011
Fondamenti di Informatica 1 Prof. B.Buttarazzi A.A. 2010/2011 Sommario Paradigma OO Oggetti e Classi Metodi Parametri Variabili di istanza Costruttori Esercizi Paradigma Object-Oriented Il paradigma OO
Laboratorio di Python
Laboratorio di Python Variabili e Funzioni Lab02 1 Marzo 2017 Outline Variabili modificabili Teoria Esempi ed esercizi Funzioni Teoria Esempi ed esercizi Esercizi per casa Outline Variabili modificabili
Laboratorio di programmazione
Laboratorio di programmazione Lezione VIII Tatiana Zolo tatiana.zolo@libero.it 1 PROGRAMMAZIONE A OGGETTI Quando si programma a oggetti si scompone il problema in sottogruppi di parti collegate che tengono
Programmazione con Java
Programmazione con Java Classi e istanze in Java Definizione di classe in Java A meno che non si usino classi già scritte da altri, prima di poter creare un qualsiasi oggetto devo creare la sua rappresentazione:
CORSO LINUX PER LA CERTIFICAZIONE LPI ESSENTIALS
CORSO LINUX PER LA CERTIFICAZIONE LPI ESSENTIALS Comandi da terminale Il comando sleep fa attendere un comando prima dell'esecuzione. Prova il comando: $ sleep 3s && echo Ciao Mondo! $ Comandi da terminale
Programmare in Python e uscirne incolumi #3. docente Vito Tafuni aa 2017/2018
Programmare in Python e uscirne incolumi #3 docente Vito Tafuni aa 27/28 + Di più sulle Stringhe I tipi stringa sono delle sequenze... di caratteri. È possibile utilizzare indici numerici per individuare
public static boolean occorre (int[] a, int n) { int i = 0; boolean trovato = false;
Metodi iterativi con array monodimensionali 1. Scrivere un metodo che, dato un array di interi a, restituisce il valore minimo in a. public static int minimo (int[] a) { int min = a[0]; for (int i=1; i
Modulo III - Cenni alla programmazione in R
Modulo III - Cenni alla programmazione in R Elisabetta Ronchieri Università di Ferrara Dipartimento di Economia e Management e-mail: elisabetta.ronchieri@unife.it 12 Dicembre 2016 Elisabetta Ronchieri
Quando usiamo Python in modo interattivo in genere e' lo shell utilizzato che gestisce l'indentazione e la deindentazione.
INDICE Indentazione note sull'indentazione in script e moduli scritti con un editor di testo. istruzione if Truth testing in cicli if e while istruzione for istruzione while Uscita dai cicli for e while
CORSO DI PROGRAMMAZIONE
ISTITUTO TECNICO INDUSTRIALE G. M. ANGIOY SASSARI CORSO DI PROGRAMMAZIONE INTRODUZIONE ALLE ISTRUZIONI ITERATIVE DISPENSA 03.01 03-01_Iterazioni_[ver_15] Questa dispensa è rilasciata sotto la licenza Creative
Programmazione strutturata IV e Gli array. Dove siamo. Un esercizio. Oggi. Schema 1. Prima idea. 7. Programmazione strutturata 4 & Array
Programmazione strutturata IV e Gli array Stefano Mizzaro Dipartimento di matematica e informatica Università di Udine http://www.dimi.uniud.it/mizzaro/ mizzaro@uniud.it Programmazione, lezione 7 18/10/2013
Introduzione a Java. Riferimenti
Introduzione a Java Si ringraziano Massimiliano Curcio e Matteo Giacalone 1: Introduction 1 Riferimenti! Java tutorial: http://java.sun.com/docs/books/tutorial/! Il Java tutorial è parte di una più ampia
JavaScript Core Language. Prof. Francesco Accarino IIS Atiero Spinelli Sesto San Giovanni via leopardi 132
JavaScript Core Language Prof. Francesco Accarino IIS Atiero Spinelli Sesto San Giovanni via leopardi 132 Condizioni L utilizzo di operatori relazionali e logici consente di formulare delle condizioni
I tipi di dati. Il comando dir. Capitolo 4
Capitolo 4 I tipi di dati Dopo tante lungaggini burocratiche, entriamo finalmente nel vivo del linguaggio. Entriamo alla grande, esplorando uno degli aspetti più peculiari di Python: i suoi spettacolari
If Statement. Il costrutto condizionale if ha la seguente sintassi:
Costrutti Control Flow Con control flow (o strutture di controllo) si intende l insieme dei costrutti che servono a gestire il flusso di esecuzione di un programma, cioè a specificare quando e come eseguire
Si può scrivere un programma anche utilizzando un editor di testo (Blocco Note, WordPad, ) ricordandosi comunque di salvarlo con l estensione.py.
Avviare il programma (Tutti i Programmi Python 2.7 Idle). Quello che si è avviato è l ambiente di sviluppo di Python, che serve per facilitare il programmatore nello scrivere programmi usando Python. Dalla
Algoritmi e Strutture di Dati
Algoritmi e Strutture di Dati Capitolo 4 - Strutture di dati elementari This work is licensed under the Creative Commons Attribution-NonCommercial-ShareAlike License. To view a copy of this license, visit
Numeri e stringhe. Andrea Passerini Conoscenze informatiche e relazionali Corso di laurea in Scienze dell Ingegneria Edile
Andrea Passerini passerini@dsi.unifi.it Conoscenze informatiche e relazionali Corso di laurea in Scienze dell Ingegneria Edile Numeri Principali tipi numerici interi normali interi con una gamma prefissata
Fondamenti di Programmazione
Fondamenti di Programmazione Capitolo 2 Variabili, Espressioni e Comandi Prof. Mauro Gaspari: gaspari@cs.unibo.it Valori e Tipi Un valore (= value) è una delle entità fondamentali che i programmi sono
Parametri by reference. Funzioni. Passaggio dei parametri. Parametri by reference. Soluzione. Problemi
Funzioni Introduzione Operatori & e * Passaggio by reference Passaggio di vettori Esercizio strcpy 2 Passaggio dei parametri Il linguaggio C prevede il passaggio di parametri by value Il chiamato non può
Tecnologie dell'informazione e della Comunicazione
Tecnologie dell'informazione e della Comunicazione Capitolo 11 Classi e Oggetti Prof. Mauro Gaspari: gaspari@cs.unibo.it Definire nuovi tipi? Abbiamo visto diversi tipi di dato strutturati: stringhe liste
Futures Esempi di codice
:Future[T] :T Futures val x = future { someexpensivecomputation() val y = future { someotherexpensivecomputation() val z = for (a
Lezione 6 Introduzione al C++ Mauro Piccolo
Lezione 6 Introduzione al C++ Mauro Piccolo piccolo@di.unito.it Linguaggi di programmazione Un linguaggio formale disegnato per descrivere la computazione Linguaggi ad alto livello C, C++, Pascal, Java,
Capitolo 5 - Funzioni
Capitolo 5 - Funzioni Divide and conquer Introduzione Costruire un programma da pezzi più piccoli o da singole componenti Questi pezzi più piccoli sono chiamati moduli Ogni singolo pezzo è più facilmente
ML è un linguaggio interattivo La modalità interattiva di OCaml Ciclo: LETTURA, VALUTAZIONE, STAMPA. Objective Caml version 3.06
1 ML è un linguaggio interattivo La modalità interattiva di OCaml Ciclo: LETTURA, VALUTAZIONE, STAMPA # Objective Caml version 3.06 Il cancelletto è il prompt di Caml. # 3*8;; - : int = 24 LETTURA: viene
Programmare Ottenere Python Primi passi Tipi dati Funzioni Approfondimenti. Un introduzione a Python 7 maggio 2012
Un introduzione a Python 7 maggio 2012 Programmi e linguaggi Programma: Serie di istruzioni che indicano al computer quali operazioni svolgere. Programmi e linguaggi Programma: Serie di istruzioni che
print((math.floor(1345/10)%10); print (Math.floor(1345/100)%10); Le funzioni in JavaScript
Funzioni Funzioni predefinite della libreria matematica Funzioni disponibili: Math.sqrt(x) radice quadrata Math.log(x) logaritmo naturale in base e di x Math.abs(x) valore assoluto di x Math.ceil(x) arrotonda
Corso di Laboratorio di Sistemi Operativi
Corso di Laboratorio di Sistemi Operativi Lezione 4 Alessandro Dal Palù email: alessandro.dalpalu@unipr.it web: www.unipr.it/~dalpalu Approfondimento su make http://http://capone.mtsu.edu/csdept/facilitiesandresources/make.htm
Fondamenti di Informatica T-1
Fondamenti di Informatica T-1 Introduzione al linguaggio Java - Input/Output, Variabili, Tipi Tutor: Allegra De Filippo allegra.defilippo@unibo.it a.a. 2015/2016 Fondamenti di Informatica T-1 Allegra De