Wiki Ubuntu-it

Indice
Partecipa
FAQ
Wiki Blog
------------------
Ubuntu-it.org
Forum
Chiedi
Chat
Cerca
Planet
  • Pagina non alterabile
  • Informazioni
  • Allegati
  • Differenze per "Programmazione/Python"
Differenze tra le versioni 23 e 115 (in 92 versioni)
Versione 23 del 26/09/2006 10.48.48
Dimensione: 13733
Commento: formattazione del documento, alcune correzioni
Versione 115 del 16/05/2024 22.42.32
Dimensione: 15831
Commento: +24.04
Le cancellazioni sono segnalate in questo modo. Le aggiunte sono segnalate in questo modo.
Linea 1: Linea 1:
## page was renamed from LinguaggioPython
## page was renamed from Linguaggio Python
#format wiki
Linea 2: Linea 5:
[[BR]]
||<tablestyle="float:right; font-size: 0.9em; width:40%; background:#F1F1ED; margin: 0 0 1em 1em;" style="padding:0.5em;">'''Indice'''[[BR]][[TableOfContents]]||
<<BR>>
<<Indice(depth=2)>>
<<Informazioni(forum="http://forum.ubuntu-it.org/viewtopic.php?t=443446"; rilasci="24.04 22.04 20.04 18.04 16.04")>>
Linea 8: Linea 11:
Python è un linguaggio di programmazione ideato da Guido Von Rossum nel 1991 e derivato da un precedente linguaggio chiamato ABC.
È interpretato e quindi caratterizzato da una grande portabilità su differenti piattaforme (Linux, Windows, Mac, ...).[[BR]]
Python è estensibile tramite il linguaggio C. Può inoltre appoggiarsi a molte famose librerie scritte in C o C++ per la creazione di GUI (wxpython, pygtk...), tool per lo svilippo di giochi (pygame, pysdl...), database (mysqldb, ...).[[BR]]
È un linguaggio ad alto livello, ha una sintassi molto piacevole e intuitiva (ideale per chi si avvicina alla programmazione). I programmi scritti in python risultano spesso molto sintetici ed eleganti nella forma (ma ricordiamo che tutto dipende anche dallo stile personale del programmatore! ;) ).[[BR]]
È nativamente un linguaggio orientato agli oggetti ma a differenza di altri linguaggi come il java permette anche uno stile procedurale e/o funzionale.[[BR]]
Ideale per realizzare applicazioni velocemnete, è utilizzato per una vasta gamma di scopi: scripting, creazione di programmi completi, estensioni di programmi scritti in C, realizzazione di prototipi di applicazioni che andranno poi riscritte in altri linguaggi.


= Installazione =

Con l'installazione predefinita di Ubuntu l'interprete python viene già installato. In caso contrario, è sufficiente installare il pacchetto ''python'' da utilizzando [:SynapticHowto:Synaptic] o da riga di comando: {{{
sudo apt-get install python
}}}

== Verifica della configurazione ==

Bene ora non resta che lanciare l'interprete interattivo e fare pratica.

Aprire un terminale e digitare: {{{
'''Python''' è un linguaggio di programmazione ad [[https://it.wikipedia.org/wiki/Linguaggio_di_programmazione_ad_alto_livello|alto livello]] che ha raggiunto una grandissima popolarità ed è utilizzato in molti ambiti, dall'utilizzo di semplici script personali fino alla creazione di progetti altamente professionali.

L'utilizzo di una sintassi pulita e ordinata legate a una certa facilità di utilizzo, hanno fatto si che col tempo '''Python''' si sia rivelato ottimale come primo linguaggio da imparare per chi è interessato ad affacciarsi al mondo della programmazione.

La seguente pagina intende solo mostrare come utilizzare gli strumenti basilari su '''Ubuntu'''. Per approfondire l'utilizzo di '''Python''' si rimanda alla copiosa documentazione presente sul web. Nel capitolo [[#guide|Guide per principianti]] sono presenti alcune delle più apprezzate guide per muovere i primi passi.

= Python 2 e 3 =

'''Python''' è stato concepito già negli anno '80. Viene rilasciato Python 1.0 nel 1994, mentre la versione 2.0 vede la luce nel 2000. Nel 2008 viene rilasciata la versione '''3''', che ha determinato un punto di cesura con la versione 2, tant'è che le due versioni sono incompatibili fra di loro.

Dopo un lungo periodo di convivenza fra '''Python 2''' e '''Python 3''', caratterizzato da una lenta fase di transizione, si è giunti al [[https://www.python.org/doc/sunset-python-2/|termine del supporto di Python 2]] il 1 gennaio del 2020. Ciò vuol dire che per la versione 2 non sono garantiti implementazioni e correzioni di bug, anche relativi alla sicurezza.<<BR>>
Si consideri tuttavia che, nonostante lo sviluppo di nuove funzionalità sia incentrato su '''Python 3''', tantissimi progetti sono ancora basati su '''Python 2'''.

== Situazione su Ubuntu ==

 * '''Ubuntu 24.04''': è preinstallata solo la versione '''Python 3.12'''; non ci sono versioni di '''Python 2''' disponibili nei repository.
 * '''Ubuntu 22.04''': è preinstallata solo la versione '''Python 3.10'''; la versione '''Python 2.7''' è disponibile nei repository.
 * '''Ubuntu 20.04''': è preinstallata solo la versione '''Python 3.8'''; la versione '''Python 2.7''' è disponibile nei repository.
 * '''Ubuntu 18.04''': sono preinstallate le due differenti versioni '''Python 2.7''' e '''Python 3.6'''.

{{{#!wiki note
Il pacchetto '''python3''' ed il relativo comando da terminale fanno riferimento, a seconda della versione di Ubuntu in uso, a Python '''3.6''', '''3.8''' o '''3.10'''. Al contrario con il pacchetto e il comando '''python''' si intende la '''versione 2.7'''. Pertanto con il generico '''python''' su Ubuntu si intende ancora la '''versione 2'''.
}}}

{{{#!wiki tip
Su [[UbuntuPhone|Ubuntu Phone]] è installata in modo predefinito la sola versione 3, nominata '''python3'''.
}}}

== Repository di terze parti ==

Oltre a quelle presenti nei [[Repository|repository ufficiali]], sono disponibili altre versioni di '''Python''', utili sia per soddisfare le necessità di versioni differenti per software provenienti da fonti terze, sia per provare versioni più recenti.

Le versioni disponibili sono:
 * '''Ubuntu 24.04''': Python 3.7, Python 3.8, Python 3.9, Python 3.10, Python 3.11 e Python 3.13
 * '''Ubuntu 22.04''': Python 3.7, Python3.8, Python3.9 e Python 3.11 Python 3.12
 * '''Ubuntu 20.04''': Python 3.5, Python 3.6, Python 3.7, Python3.9, Python3.10 e Python 3.11, Python 3.12
 * '''Ubuntu 18.04''': Python2.3, Python 2.4, Python 2.5, Python 2.6, Python 3.1, Python 3.2, Python 3.3, Python 3.4, Python 3.5, Python 3.7, Python 3.8, Python3.9, Python 3.10 e Python 3.11

##Non cancellare questa nota, probabilmente sarà utile per Python 4
##{{{#!wiki important
##Python 3.11, seppur sufficientemente stabile per uso comune, è ancora in fase beta. Si consiglia di usarlo solo per test e/o sviluppo.
##}}}

Per installare queste versioni:

 0. Digitare nel [[AmministrazioneSistema/Terminale|terminale]] i comandi per aggiungere i '''PPA deadsnakes team''':{{{
sudo add-apt-repository ppa:deadsnakes/ppa
sudo apt update
}}}
 0. [[AmministrazioneSistema/InstallareProgrammi|Installare]] i pacchetti desiderati (per facilitare la ricerca è possibile utilizzare l'apposita [[AmministrazioneSistema/InstallareProgrammi/Apt#Altre_operazioni|funzione]] oppure un [[AmministrazioneSistema/InstallareProgrammi#Tramite_interfaccia_grafica|gestore pacchetti]] dotato di interfaccia grafica).
 0. Al termine dell'installazione riavviare il sistema.

== Distribuzione Anaconda ==

{{{#!wiki note
L'applicazione '''Anaconda''' ha una dimensione di diverse centinaia di megabyte, occorre quindi uno spazio d'archiviazione nel sistema sufficientemente ampio per poterlo installare. Si consiglia una dimensione d'almeno 1 gigabyte.}}}
##Non ho potuto verificare se è ancora disponibile il ''Python 2'''.
[[https://www.anaconda.com/|Anaconda]] è una distribuzione di '''Python''', sia in versione '''Python 2''' che '''Python 3''', realizzata specificatamente per la [[https://it.wikipedia.org/wiki/Scienza_dei_dati|data science]]. Per installarla sul proprio sistema e utilizzarla come versione '''Python''' di default seguire i seguenti passaggi.

 0. Scaricare '''Anaconda''' dalla [[https://www.anaconda.com/download/|pagina ufficiale]], facendo clic sul tasto '''Download''' in alto a destra nella casella '''Anaconda Distribution'''. La versione necessaria viene normalmente riconosciuta automaticamente; si può in ogni caso scegliere una versione per un sistema operativo differente facendo clic sul tasto '''Get Additional Installers'''.
 0. [[AmministrazioneSistema/PermessiFile#Operazioni_comuni|Assegnare i permessi di esecuzione]] al file appena scaricato.
 0. Aprire un [[AmministrazioneSistema/Terminale|terminale]] e [[AmministrazioneSistema/ComandiBase#cd|spostarsi]] nella cartella dove è stato scaricato il file.
 0. Digitare il comando:{{{
./Anaconda*.sh
}}}
 0. Quando richiesto, premere '''Invio''' per leggere la licenza d'uso.
 0. Scorrere tutta la licenza d'uso premendo ripetutamente il tasto '''Invio''', poi digitare '''yes''' e premere '''Invio'''.
 0. Scegliere in quale cartella installare Anaconda. Di default è impostata la propria '''Home'''.
 0. Digitare '''Yes''' alla richiesta di aggiornare il file `~/.bashrc`.
 0. Scegliere a seconda delle proprie esigenze se installare o meno '''Microsoft VS Studio''' digitando rispettivamente '''Yes''' o '''No'''.

= Shell python =

Come consuetudine per la realizzazione di programmi si utilizzano file di testo sui quali scrivere il codice sorgente (vedere [[#script|relativo capitolo]]). Tuttavia è possibile avviare all'interno del [[AmministrazioneSistema/Terminale|terminale]] una '''shell python''' interattiva sulla quale poter testare porzioni di codice.

 * '''Python 3''': il comando:{{{
python3
}}}avvierà la versione 3 predefinita sul proprio sistema, ad es. la 3.6 su Ubuntu 18.04:{{{
Python 3.6.9 (default, Oct 8 2020, 12:12:24)
[GCC 8.4.0] on linux
Type "help", "copyright", "credits" or "license" for more information.
>>>"
}}}Se sono state installate versioni successive, ad es. la 3.7 e la si vuole utilizzare, sarà sufficiente specificarlo nel comando:{{{
python3.7
}}}

 * '''Python 2''': il comando:{{{
python2
}}}oppure semplicemente:{{{
Linea 28: Linea 101:
}}} Dovrebbe apparire qualcosa del tipo: {{{
Python 2.4.3 (#2, Apr 27 2006, 14:43:58)
[GCC 4.0.3 (Ubuntu 4.0.3-1ubuntu5)] on linux2
}}}
 avvierà la versione 2.7. Oltre al prompt dei comandi verrà visualizzata l'intestazione:{{{
Python 2.7.6 (default, Oct 26 2016, 20:30:19)
[GCC 4.8.4] on linux2
Linea 32: Linea 106:
>>>
}}}

= Semplici comandi =

Una volta avviato l'interprete, impariamo a usarlo: {{{
>>> print "Hello World!"
>>>
}}}

== Esempi in Python 3 ==

{{{#!wiki tip
Per testare i seguenti esempi è sufficiente digitare i comandi che appaiono accanto alla tripla freccia del prompt ('''>>>''') e quindi premere '''Invio'''.
}}}

 * Alcune semplici istruzioni da passare al prompt per stampare scritte e per effettuare calcoli aritmetici. Le [[https://it.wikipedia.org/wiki/Stringa_(informatica)|stringhe]] devono essere inserite in mezzo alle virgolette `" "`, mentre i numeri vengono digitati così come sono:{{{
>>> print("Hello World!")
Linea 40: Linea 118:
>>> print  2+3 >>> print(2+3)
Linea 42: Linea 120:
>>> print  "2 + 3 = ", 2+3 >>> print("2 + 3 = ", 2+3)
Linea 46: Linea 124:
Usciamo dall'interprete premendo «`Ctrl+D`», oppure digitando: {{{
>>> import sys
>>> sys.exit()
}}}

Proviamo ora a realizzare un piccolo script.

Apriamo un editor di testo qualsiasi e inseriamo le seguenti righe: {{{#!python
#!/usr/bin/python
print "Hello World!"
}}}

Salviamo il file come `hello.py` e impostiamone i permessi di esecuzione: {{{
chmod a+x hello.py
}}}

Ora eseguiamo lo script: {{{
python hello.py
}}}

Se non è sbagliato qualcosa, si dovrebbero vedere le parole "Hello World!" stampate a video.

= Esempi =

Ora che vi abbiamo un po' incuriosito vi proponiamo in questa sezione diversi script esemplificativi a difficoltà crescente.

[[Immagine(Icone/Piccole/note.png,,left)]] Tutto ciò che viene scritto preceduto dal carattere # è considerato dall'interprete come un commento.[[BR]][[BR]]
[[BR]]
[[Anchor(areatriangolo1)]]
{{{#!python
#!/usr/bin/python#
import sys
import string
import math
''' questa è un'area di commento che uso per indicare cosa fa il programa o sorgente o script
    il programma principale o il main calcola l'area di un triangolo qualsiasi noti i suoi tre
    lati usando la formula di Erone
    formula sqrt p*(p-a)*(p-b)*p(-c) sqrt = radice quadrata, p = (a+b+c)/2 a,b,c lati
    salvatelo sul disco con il nome che vi propongo AreaTriangolo.py o come più vi piace
'''
a = input('inserisci il primo lato ')
print ' primo lato = ',a
b = input('inserisci il secondo lato ')
print ' secondo lato = ',b
c = input('inserisci il terzo lato ')
print ' terzo lato = ',c
print
print " ora calcolo l'area di questo triangolo"
print
p = (a+b+c)/2
s = math.sqrt(p*(p-a)*(p-b)*(p-c))

print " l'area del triangolo e' =" ,s
}}} ''Listato del programma Area``Triangolo.py''
[[BR]][[BR]]

Il programma precedente termina se durante l'inserimento dei dati, per errore, viene digitato un carattere non numerico. È necessario quindi inserire un controllo sul dato immesso. A questo scopo è stato preparato questo altro programmino che slaviamo nel file `AreaTriangolo2.py`:
[[Anchor(areatriangolo2)]]
{{{#!python
#!/usr/bin/python
import sys
import math
import string
i = 0
l=[]
while True:
 a= raw_input('inserisci il '+str(i+1)+' lato ')
        for j in range(len(a)) :
  errato = 'F'
  if a[j] in string.digits:
   errato = 'F'
   continue #continua il ciclo for
  else:
   errato = 'T'
   print "hai digitato qualcosa che non è un numero.Riprova"
   break # termina il ciclo for
 if errato =='T':
  continue #continua il ciclo while
   
 i +=1
 l.append(float(a)) # completata la verifica che il dato inserito e' una cifra viene trasformata in un numero a virgola mobile e inserita in un array
        if errato =='F'and i <3:
  # questo controllo ci serve per riprendere l'inserimento dei dati dopo aver completato il controlo
                # sul dato precedente
  continue # continua il ciclo while per passare al successivo input
 elif errato =='F' and i >=3:

  print ' primo lato = ',l[0]
  print
  print ' secondo lato = ',l[1]
  print
  print ' terzo lato = ',l[2]
  print
  p = (l[0]+l[1]+l[2])/2.0 # calcola il semi perimetro
  if p > l[0] and p>l[1] and p >l[2]:
   print " ora calcolo l'area di questo triangolo"
   break # esce dal ciclo while per fine input
  else:
   print "questi lati non appartengono ad un triangolo. Riprova "
   i =0
   l=[]
   continue # continua nel ciclo while per ricominciare i nuovi input
 
 
  
 

print

s = math.sqrt(p*(p-l[0])*(p-l[1])*(p-l[2]))

print " l'area del triangolo e' =" ,s
print
print "Fine programma "
}}} ''Listato del programma Area``Triangolo2.py''
[[BR]][[BR]]

Mostriamo anche un'alternativa che utilizza le classi e la gestione delle eccezioni modificando il programma precedente:
{{{#!python
#!/usr/bin/python

# Importiamo la funzione sqrt (radice quadrata) dal modulo math
from math import sqrt

# Definiamo una classe Triangolo con tre metodi:
# un costruttore, un metodo che calcola il perimetro e uno che calcola l'area del triangolo.
class Triangolo:

      # Attributi della classe (le misure dei tre lati)
      a, b, c = 0, 0, 0

      # Metodo costruttore
      def __init__(self,a,b,c):
         # Controlliamo se i tre valori dati possono effettivamente essere le misure dei lati di un triangolo.
         # Caso contrario solleviamo una bella eccezione!
         if ((a+b>c) and (a+c>b) and (b+c>a)):
            self.a=a
            self.b=b
            self.c=c
         else: raise Exception

      # Metodo che calcola il perimetro
      def perimetro(self):
         return self.a + self.b + self.c

      # Metodo che calcola l'area (tramite formula di Erone)
      def area(self):
         p=self.perimetro()/2.0
         return sqrt(p*(p-self.a)*(p-self.b)*(p-self.c))


 
while True:
      # Chiediamo all'utente di immettere le misure dei lati
      print "\nInserire le misure dei lati:"
      lati=[]
      for lato in ['a','b','c']:
          while True:
               try :
                  l=raw_input("\tMisura del lato "+lato+": ")
                  lati.append(float(l))
                  break
               except ValueError:
                  print "\nDevi inserire valori numerici. Riprova.\n"

      try :
         # Creiamo una nuova istanza della classe Triangolo.
         # In pratica facciamo una chiamata al suo metodo costruttore.
         # Sarebbe stato lo stesso scrivere "triangolo=Triangolo.__init__(a,b,c)"
         triangolo=Triangolo(lati[0],lati[1], lati[2])

         # Utilizziamo i metodi definiti in precedenza per ottenere perimetro ed area dell'oggetto triangolo,
         # e stampiamo a video i risultati.
         print ""
         print "Perimetro = ", triangolo.perimetro()
         print "Area = ", triangolo.area()

         # Chiediamo all'utente se terminare il programma.
         exit=raw_input("\nUscire [digitare 's' per confermare]? ")
         print ""
         if exit=="s": break

      except:
         print "\nUn triangolo con queste misure non esiste. Riprova."

}}} ''Listato del programma Area``Triangolo2.py con eccezioni''
[[BR]][[BR]]

Ora supponiamo di dover calcolare l'area di un appezzamento di terreno di svariati ettari scomposto in un numero finito di triangoli.[[BR]]
Una volta nota l'area, supponiamo che debba essere divisa, per volontà testamentaria, in tre parti in funzione dell'età di tre fratelli i cui nomi sono Angelo, Alberto, Amilcare o come volete voi.

Useremo lo stesso programma [#areatriangolo2 AreaTriangolo2.py], con qualche modifica o aggiunta, che chiameremo `AreaTriangolo3.py`: {{{#!python
#!/usr/bin/python
import sys
import math
import string
# fase di input
nomi = []
eta= []
lati= []
x= 1
while x <=3:
 a= raw_input('Inserici nome '+str(x)+' fratello ')
 #verifichiamo l'input immesso
 errore = 'F'
 for i in range(len(a)):
  if a[i] in string.letters:
   continue
  else:
   if i <= len(a):
    print "errore nell'immettere il nome .riprova"
    errore = 'T'
    break
 if errore == "T":
  continue
 else:
  # lo rendiamo tutto maiuscolo indipendentemente se lo sia o meno
  nomi.append(string.upper(a))
  print nomi
  x +=1
  
#ora prendiamo in input le loro eta
x = 0

while x < range(len(nomi)):
 
 a= raw_input("inserisci l'eta di "+nomi[x]+' ')
        for j in range(len(a)) :
  errato = 'F'
  if a[j] in string.digits:
   errato = 'F'
   continue #continua il ciclo for
  else:
   errato = 'T'
   print "hai digitato qualcosa che non è un numero.Riprova"
   break # termina il ciclo for
 if errato =='T':
  continue #continua il ciclo while
   
 x +=1
 eta.append(int(a))
        if errato =='F'and x <3:
  
  continue # continua il ciclo while per passare al successivo input
 elif errato =='F' and x >=3:
  print ' Eta di' +nomi[0] +" "+ str( int(eta[0]))
  print
  print ' Eta di' +nomi[1] +" "+ str( int(eta[1]))
  print
  print ' Eta di' +nomi[2] +" "+ str( int(eta[2]))
  print
  break
#input dei dati per il calcolo dell'area dell'appezzamento
  
i = 0
l=[]
tria = []
while True:
 a= raw_input('inserisci il '+str(i+1)+' lato ')
        for j in range(len(a)) :
  errato = 'F'
  if a[j] in string.digits:
   errato = 'F'
   continue #continua il ciclo for
  else:
   errato = 'T'
   print "hai digitato qualcosa che non è un numero.Riprova"
   break # termina il ciclo for
 if errato =='T':
  continue #continua il ciclo while
   
 i +=1
 l.append(float(a))
        if errato =='F'and i <3:
  # questo controllo verifica se abbiamo termianto i dati in input relativi ad un triangolo
  continue # continua il ciclo while per passare al successivo input
 elif errato =='F' and i >=3:
                # qui avendo termianto l'input dei dati relativi ad un trinagolo li ripresenta a video per maggior chiarezza
  print ' primo lato = ',l[0]
  print
  print ' secondo lato = ',l[1]
  print
  print ' terzo lato = ',l[2]
  print
  p = (l[0]+l[1]+l[2])/2.0
  if p > l[0] and p>l[1] and p >l[2]:
   print " l'area di questo triangolo e' calcolabile"
   tria.append(l)
   l=[]
   si = raw_input(" hai finito di immettere lati dei triangoli ? conferma con S/s ")
   if si == "S" or si =='s':
    print "Inizia la fase di calcolo "
    break # esce dal ciclo while per fine input
   else:
    i =0
    l=[]
    continue # continua nel ciclo while per input dati nuovo triangolo
  else:
   print "questi lati non appartengono ad un triangolo. Riprova "
   i =0
   l=[]
   continue # continua nel ciclo while perche dati in input del triangolo errati
 
 
#fase di calcolo area appezzamento
n = len(tria) # il calcolo dell'area verrà ripetuto n volte una per ogni triangolo

p = 0
stot = 0
for i,l in enumerate(tria):
 for j in range( len(l)):
  print l[j]
         p = p+l[j]
        print "semiper. nel "+str(i+1)+ " triangolo = "+ str(p/2.0)
        print
 p=p/2.0
 s = math.sqrt(p*(p-l[0])*(p-l[1])*(p-l[2]))
 print "area "+str(i+1)+ " triangolo = "+ str(s)
 print
 stot = stot +s
 p=0
print
print "l'area totale dell'appezamento di terreno e di mq " + str(stot)
print
print "ora calcoliamo quanto terreno spetta a ciascuno dei tre fratelli"

seta = 0
for i in eta:
 seta=seta+i
 
 
areau =(stot/seta)

for i in eta:
 a =areau*i
 nomi.append(a)
for i in range(0,3):
 print "l'area spettante a " +nomi[i] + " somma mq. "+ str(nomi[i+3])
        print
 
print' Fine programma '

}}} ''Listato del programma Area``Triangolo3.py''
[[BR]][[BR]]

Questo programma cosi come è realizzato è un po troppo lungo e considerati i numerosi cicli in esso contenuto può farci incorrere in errori. Come possiamo renderlo piu snello e piu facilemnte governabile?

= Risorse =

 * [http://www.python.it/] {it} [[BR]]
 Il sito di riferimento per i programmatori python italiani! Qui potete trovare le traduzioni in italiano della documentazione ufficiale nonchè le FAQ sul linguaggio.
 
 * [http://www.python.org/] {en} [[BR]]
 Il sito ufficiale del linguaggio python. Trovate la documentazione in inglese aggiornata all'ultima versione dell'interprete, in più tutte le novità e le iniziative che ruotano intorno a questo linguaggio.
 * Per indicare i blocchi di codice si usa l'indentazione creata tramite il tasto '''TAB''' (Tab ⇆). In '''Python''' non è solo una buona abitudine del programmatore ma è obbligatoria. Per esempio il codice appartenente a un ciclo deve essere indentato:{{{
>>> i = 0
>>> while i < 4:
... i += 1
... print("il doppio di", i, " e' ", i*2)
...
il doppio di 1 e' 2
il doppio di 2 e' 4
il doppio di 3 e' 6
il doppio di 4 e' 8
}}}Altrimenti succede questo:{{{
>>> i = 0
>>> while i < 4:
... i += 1
  File "<stdin>", line 2
    i += 1
    ^
IndentationError: expected an indented block
}}}
 * Uscire dall'interprete premendo '''Ctrl+D''', oppure digitando il comando:{{{
>>> exit()
}}}

= Impostare versione Python3 =

Da predefinito il sistema usa la versione preinstallata, per impostare l'uso d'una versione installata a posteriori è sufficiente modificare il collegamento simbolico al comando base.

Nel seguente esempio si sostituisce la versione predefinita '''3.6''' con la '''3.7'''.

 0. Visualizzare le versioni installate digitando nel [[AmministrazioneSistema/Terminale|terminale]] il comando:{{{
ls /usr/bin/python* -l
}}}mostrerà una lista simile:{{{
lrwxrwxrwx 1 root root 9 mag 6 2018 /usr/bin/python -> python2.7
lrwxrwxrwx 1 root root 9 mag 6 2018 /usr/bin/python2 -> python2.7
-rwxr-xr-x 1 root root 3628976 set 30 15:38 /usr/bin/python2.7
lrwxrwxrwx 1 root root 9 ott 25 2018 /usr/bin/python3 -> python3.6
-rwxr-xr-x 2 root root 4526456 ott 8 14:12 /usr/bin/python3.6
lrwxrwxrwx 1 root root 9 ott 25 2018 /usr/bin/python3m -> python3.6m
-rwxr-xr-x 2 root root 4526456 ott 8 14:12 /usr/bin/python3.6-config
lrwxrwxrwx 1 root root 9 ott 25 2018 /usr/bin/python3.7
-rwxr-xr-x 2 root root 4526456 ott 8 14:12 /usr/bin/python3.7m
-rwxr-xr-x 2 root root 4526456 ott 8 14:12 /usr/bin/python3.7-config
}}}
 0. Per sostituire l a versione '''3.6''' con la versione '''3.7''' digitare i comandi:{{{
sudo rm /usr/bin/python3
sudo rm /usr/bin/python3m
sudo rm /usr/bin/python3-config
sudo ln -s /usr/bin/python3.7 /usr/bin/python3
sudo ln -s /usr/bin/python3.7m /usr/bin/python3m
sudo ln -s /usr/bin/python3.7-config /usr/bin/python3-config
}}}

{{{#!wiki note
I collegamenti da sostituire sono individuabili nella lista mostrata dal primo comando dalla presenza del simbolo '''->''' nella stringa.
}}}

{{{#!wiki important
Non miscelare i collegamenti simbolici ai Python2 e 3, poiché sono incompatibili tra loro.
}}}

Riavviare il sistema per rendere effettiva la modifica.

<<Anchor(script)>>
= Script =

Come esempio pratico verrà creato un file con del codice '''Python 3''' al suo interno che potrà essere richiamato dal terminale per essere eseguito.

<<Anchor(primo)>>
== Primo metodo ==

 0. Aprire un [[Ufficio/EditorDiTesto|editor di testo]] e inserire le seguenti righe:{{{
print("Ciao mondo!")
}}}
 0. Salvare nella propria '''Home''' il file come `ciao.py`.
 0. Da [[AmministrazioneSistema/Terminale|terminale]] digitare:{{{
python3 ciao.py
}}}
 0. Verrà restituita la scritta:{{{
Ciao mondo!
}}}

<<Anchor(secondo)>>
== Secondo metodo ==

Nel comando del [[#primo|primo metodo]] `python3 ciao.py` può essere evitata la digitazione del termine `python3`, inserendo all'inizio dello script la direttiva:{{{
#!/usr/bin/env python3
#!/usr/bin/env python3
}}}In alternativa è comune trovare la forma `#!/usr/bin/python3`.

 0. Modificare il contenuto dello script in modo che risulti:{{{
#!/usr/bin/env python3
#!/usr/bin/env python3

print("Ciao mondo!")
}}}
 0. Rendere lo script eseguibile con il comando:{{{
chmod u+x ciao.py
}}}
 0. Lanciare quindi lo script con il comando:{{{
./ciao.py
}}}che restituirà la scritta:{{{
Ciao mondo!
}}}

== Alcune differenze con Python 2 ==

 * Partendo dallo script [[#primo|iniziale]] in '''Python 3''' si nota già una differenza fondamentale nella sintassi. L'istruzione `print` è stata sostituita in '''Python 3''' con la funzione `print()`. In '''Python 2''' il comando nello script è:{{{
print "Ciao mondo!"
}}}
 * Il comando di avvio del primo metodo deve essere adattato alla versione '''2''' di '''Python''', pertanto diviene:{{{
python2 ciao.py
}}}oppure semplicemente:{{{
python ciao.py
}}}
 * Andando a inserire la direttiva `#!/usr/bin/env python3` come nel [[#secondo|secondo metodo]], anch'essa dovrà essere rapportata a '''Python 2''', quindi:{{{
#!/usr/bin/env python2
#!/usr/bin/env python2
}}}oppure semplicemente:{{{
#!/usr/bin/env python
#!/usr/bin/env python
}}}

= Guide di approfondimento =

 * [[Programmazione/Python/Listati|Listati Python 2]]: esempi script esemplificativi presenti in alcuni programmi scritti in '''Python 2''' a difficoltà crescente.
 * [[Programmazione/Python/ListatiPython3|Listati Python 3]]: esempi script esemplificativi presenti in alcuni programmi scritti in '''Python 3''' a difficoltà crescente.
 * [[Programmazione/Python/Pip|Pip]]: guida a '''pip''', gestore di pacchetti per '''Python''', utile per installare moduli, librerie, frameworks, vari software per sviluppo, ricerca scientifica, svago ecc.
 * [[Programmazione/Python/InterfacceGrafiche|Interfacce grafiche]]: esempi di alcuni programmi scritti in '''Python 2.7.xx''' con semplice interfaccia grafica.
 * [[Programmazione/Python/InterfacceGrafichePython3|Interfacce grafiche Python 3]]: esempi di alcuni programmi scritti in '''Python 3.x''' con semplice interfaccia grafica.
 * [[Programmazione/Python/Glade|Glade]]: guida a '''Glade''', strumento per creare interfacce grafiche in '''GTK+''' compatibili con '''Python'''.

<<Anchor(guide)>>
= Guide per principianti =

I seguenti testi (principalmente in '''inglese''') sono indicati per chiunque si voglia avvicinare per la prima volta a un linguaggio di programmazione.

== Python 2 ==

 * [[http://www.python.it/doc/Howtothink/Howtothink-html-it/index.htm|Pensare da informatico]] di Allen B. Downey, Jeffrey Elkner e Chris Meyers (in '''italiano''').
 * [[https://learnpythonthehardway.org/book|Learn Python the hard way]] di Zed A. Shaw.
 * [[http://www.python.it/doc/AGauld/index.html|Imparare a programmare]] di Alan Gauld (in '''italiano''').

== Python 3 ==

 * [[https://www.programmareinpython.it/programmare-in-python/|programmareinpython.it]]: video corso con testo riportato di ogni lezione (in '''italiano''').
 * [[https://github.com/AllenDowney/ThinkPythonItalian/blob/master/thinkpython_italian.pdf|Pensare da informatico]] di Allen B. Downey, Jeffrey Elkner e Chris Meyers (in '''italiano''').
 * [[http://interactivepython.org/courselib/static/thinkcspy/index.html|How to think like a computer scientist]] riadattata da Brad Miller and David Ranum.
 * [[https://learnpythonthehardway.org/python3|Learn Python the hard way]] di Zed A. Shaw.
 * [[https://en.wikibooks.org/wiki/Non-Programmer's_Tutorial_for_Python_3|Non-Programmer's Tutorial for Python 3]] di Josh Cogliati.

= Ulteriori risorse =

 * [[https://www.python.org|Sito ufficiale]]
 * [[https://docs.python.org|Documentazione ufficiale]]
 * [[http://www.python.it|Comunità italiana di Python]]
 * [[https://it.wikipedia.org/wiki/Python|Voce enciclopedica]]
Linea 401: Linea 282:
CategoryNuoviDocumenti CategoryProgrammazione 


Guida verificata con Ubuntu: 20.04 22.04 24.04

Problemi in questa pagina? Segnalali in questa discussione

Introduzione

Python è un linguaggio di programmazione ad alto livello che ha raggiunto una grandissima popolarità ed è utilizzato in molti ambiti, dall'utilizzo di semplici script personali fino alla creazione di progetti altamente professionali.

L'utilizzo di una sintassi pulita e ordinata legate a una certa facilità di utilizzo, hanno fatto si che col tempo Python si sia rivelato ottimale come primo linguaggio da imparare per chi è interessato ad affacciarsi al mondo della programmazione.

La seguente pagina intende solo mostrare come utilizzare gli strumenti basilari su Ubuntu. Per approfondire l'utilizzo di Python si rimanda alla copiosa documentazione presente sul web. Nel capitolo Guide per principianti sono presenti alcune delle più apprezzate guide per muovere i primi passi.

Python 2 e 3

Python è stato concepito già negli anno '80. Viene rilasciato Python 1.0 nel 1994, mentre la versione 2.0 vede la luce nel 2000. Nel 2008 viene rilasciata la versione 3, che ha determinato un punto di cesura con la versione 2, tant'è che le due versioni sono incompatibili fra di loro.

Dopo un lungo periodo di convivenza fra Python 2 e Python 3, caratterizzato da una lenta fase di transizione, si è giunti al termine del supporto di Python 2 il 1 gennaio del 2020. Ciò vuol dire che per la versione 2 non sono garantiti implementazioni e correzioni di bug, anche relativi alla sicurezza.
Si consideri tuttavia che, nonostante lo sviluppo di nuove funzionalità sia incentrato su Python 3, tantissimi progetti sono ancora basati su Python 2.

Situazione su Ubuntu

  • Ubuntu 24.04: è preinstallata solo la versione Python 3.12; non ci sono versioni di Python 2 disponibili nei repository.

  • Ubuntu 22.04: è preinstallata solo la versione Python 3.10; la versione Python 2.7 è disponibile nei repository.

  • Ubuntu 20.04: è preinstallata solo la versione Python 3.8; la versione Python 2.7 è disponibile nei repository.

  • Ubuntu 18.04: sono preinstallate le due differenti versioni Python 2.7 e Python 3.6.

Il pacchetto python3 ed il relativo comando da terminale fanno riferimento, a seconda della versione di Ubuntu in uso, a Python 3.6, 3.8 o 3.10. Al contrario con il pacchetto e il comando python si intende la versione 2.7. Pertanto con il generico python su Ubuntu si intende ancora la versione 2.

Su Ubuntu Phone è installata in modo predefinito la sola versione 3, nominata python3.

Repository di terze parti

Oltre a quelle presenti nei repository ufficiali, sono disponibili altre versioni di Python, utili sia per soddisfare le necessità di versioni differenti per software provenienti da fonti terze, sia per provare versioni più recenti.

Le versioni disponibili sono:

  • Ubuntu 24.04: Python 3.7, Python 3.8, Python 3.9, Python 3.10, Python 3.11 e Python 3.13

  • Ubuntu 22.04: Python 3.7, Python3.8, Python3.9 e Python 3.11 Python 3.12

  • Ubuntu 20.04: Python 3.5, Python 3.6, Python 3.7, Python3.9, Python3.10 e Python 3.11, Python 3.12

  • Ubuntu 18.04: Python2.3, Python 2.4, Python 2.5, Python 2.6, Python 3.1, Python 3.2, Python 3.3, Python 3.4, Python 3.5, Python 3.7, Python 3.8, Python3.9, Python 3.10 e Python 3.11

Per installare queste versioni:

  1. Digitare nel terminale i comandi per aggiungere i PPA deadsnakes team:

    sudo add-apt-repository ppa:deadsnakes/ppa
    sudo apt update
  2. Installare i pacchetti desiderati (per facilitare la ricerca è possibile utilizzare l'apposita funzione oppure un gestore pacchetti dotato di interfaccia grafica).

  3. Al termine dell'installazione riavviare il sistema.

Distribuzione Anaconda

L'applicazione Anaconda ha una dimensione di diverse centinaia di megabyte, occorre quindi uno spazio d'archiviazione nel sistema sufficientemente ampio per poterlo installare. Si consiglia una dimensione d'almeno 1 gigabyte.

Anaconda è una distribuzione di Python, sia in versione Python 2 che Python 3, realizzata specificatamente per la data science. Per installarla sul proprio sistema e utilizzarla come versione Python di default seguire i seguenti passaggi.

  1. Scaricare Anaconda dalla pagina ufficiale, facendo clic sul tasto Download in alto a destra nella casella Anaconda Distribution. La versione necessaria viene normalmente riconosciuta automaticamente; si può in ogni caso scegliere una versione per un sistema operativo differente facendo clic sul tasto Get Additional Installers.

  2. Assegnare i permessi di esecuzione al file appena scaricato.

  3. Aprire un terminale e spostarsi nella cartella dove è stato scaricato il file.

  4. Digitare il comando:

    ./Anaconda*.sh
  5. Quando richiesto, premere Invio per leggere la licenza d'uso.

  6. Scorrere tutta la licenza d'uso premendo ripetutamente il tasto Invio, poi digitare yes e premere Invio.

  7. Scegliere in quale cartella installare Anaconda. Di default è impostata la propria Home.

  8. Digitare Yes alla richiesta di aggiornare il file ~/.bashrc.

  9. Scegliere a seconda delle proprie esigenze se installare o meno Microsoft VS Studio digitando rispettivamente Yes o No.

Shell python

Come consuetudine per la realizzazione di programmi si utilizzano file di testo sui quali scrivere il codice sorgente (vedere relativo capitolo). Tuttavia è possibile avviare all'interno del terminale una shell python interattiva sulla quale poter testare porzioni di codice.

  • Python 3: il comando:

    python3

    avvierà la versione 3 predefinita sul proprio sistema, ad es. la 3.6 su Ubuntu 18.04:

    Python 3.6.9 (default, Oct  8 2020, 12:12:24) 
    [GCC 8.4.0] on linux
    Type "help", "copyright", "credits" or "license" for more information.
    >>>"

    Se sono state installate versioni successive, ad es. la 3.7 e la si vuole utilizzare, sarà sufficiente specificarlo nel comando:

    python3.7
  • Python 2: il comando:

    python2

    oppure semplicemente:

    python

    avvierà la versione 2.7. Oltre al prompt dei comandi verrà visualizzata l'intestazione:

    Python 2.7.6 (default, Oct 26 2016, 20:30:19) 
    [GCC 4.8.4] on linux2
    Type "help", "copyright", "credits" or "license" for more information.
    >>> 

Esempi in Python 3

Per testare i seguenti esempi è sufficiente digitare i comandi che appaiono accanto alla tripla freccia del prompt (>>>) e quindi premere Invio.

  • Alcune semplici istruzioni da passare al prompt per stampare scritte e per effettuare calcoli aritmetici. Le stringhe devono essere inserite in mezzo alle virgolette " ", mentre i numeri vengono digitati così come sono:

    >>> print("Hello World!")
    Hello World!
    >>> print(2+3)
    5
    >>> print("2 + 3 = ",  2+3)
    2 + 3 = 5
  • Per indicare i blocchi di codice si usa l'indentazione creata tramite il tasto TAB (Tab ⇆). In Python non è solo una buona abitudine del programmatore ma è obbligatoria. Per esempio il codice appartenente a un ciclo deve essere indentato:

    >>> i = 0
    >>> while i < 4:
    ...     i += 1
    ...     print("il doppio di", i, " e' ", i*2)
    ...
    il doppio di 1  e'  2
    il doppio di 2  e'  4
    il doppio di 3  e'  6
    il doppio di 4  e'  8

    Altrimenti succede questo:

    >>> i = 0
    >>> while i < 4:
    ... i += 1
      File "<stdin>", line 2
        i += 1
        ^
    IndentationError: expected an indented block
  • Uscire dall'interprete premendo Ctrl+D, oppure digitando il comando:

    >>> exit()

Impostare versione Python3

Da predefinito il sistema usa la versione preinstallata, per impostare l'uso d'una versione installata a posteriori è sufficiente modificare il collegamento simbolico al comando base.

Nel seguente esempio si sostituisce la versione predefinita 3.6 con la 3.7.

  1. Visualizzare le versioni installate digitando nel terminale il comando:

    ls /usr/bin/python* -l

    mostrerà una lista simile:

    lrwxrwxrwx 1 root root       9 mag  6  2018 /usr/bin/python -> python2.7
    lrwxrwxrwx 1 root root       9 mag  6  2018 /usr/bin/python2 -> python2.7
    -rwxr-xr-x 1 root root 3628976 set 30 15:38 /usr/bin/python2.7
    lrwxrwxrwx 1 root root       9 ott 25  2018 /usr/bin/python3 -> python3.6
    -rwxr-xr-x 2 root root 4526456 ott  8 14:12 /usr/bin/python3.6
    lrwxrwxrwx 1 root root       9 ott 25  2018 /usr/bin/python3m -> python3.6m
    -rwxr-xr-x 2 root root 4526456 ott  8 14:12 /usr/bin/python3.6-config
    lrwxrwxrwx 1 root root       9 ott 25  2018 /usr/bin/python3.7
    -rwxr-xr-x 2 root root 4526456 ott  8 14:12 /usr/bin/python3.7m
    -rwxr-xr-x 2 root root 4526456 ott  8 14:12 /usr/bin/python3.7-config
  2. Per sostituire l a versione 3.6 con la versione 3.7 digitare i comandi:

    sudo rm /usr/bin/python3
    sudo rm /usr/bin/python3m
    sudo rm /usr/bin/python3-config
    sudo ln -s /usr/bin/python3.7 /usr/bin/python3
    sudo ln -s /usr/bin/python3.7m /usr/bin/python3m
    sudo ln -s /usr/bin/python3.7-config /usr/bin/python3-config

I collegamenti da sostituire sono individuabili nella lista mostrata dal primo comando dalla presenza del simbolo -> nella stringa.

Non miscelare i collegamenti simbolici ai Python2 e 3, poiché sono incompatibili tra loro.

Riavviare il sistema per rendere effettiva la modifica.

Script

Come esempio pratico verrà creato un file con del codice Python 3 al suo interno che potrà essere richiamato dal terminale per essere eseguito.

Primo metodo

  1. Aprire un editor di testo e inserire le seguenti righe:

    print("Ciao mondo!")
  2. Salvare nella propria Home il file come ciao.py.

  3. Da terminale digitare:

    python3 ciao.py
  4. Verrà restituita la scritta:

    Ciao mondo!

Secondo metodo

Nel comando del primo metodo python3 ciao.py può essere evitata la digitazione del termine python3, inserendo all'inizio dello script la direttiva:

#!/usr/bin/env python3

In alternativa è comune trovare la forma #!/usr/bin/python3.

  1. Modificare il contenuto dello script in modo che risulti:

    #!/usr/bin/env python3
    
    print("Ciao mondo!")
  2. Rendere lo script eseguibile con il comando:

    chmod u+x ciao.py
  3. Lanciare quindi lo script con il comando:

    ./ciao.py

    che restituirà la scritta:

    Ciao mondo!

Alcune differenze con Python 2

  • Partendo dallo script iniziale in Python 3 si nota già una differenza fondamentale nella sintassi. L'istruzione print è stata sostituita in Python 3 con la funzione print(). In Python 2 il comando nello script è:

    print "Ciao mondo!"
  • Il comando di avvio del primo metodo deve essere adattato alla versione 2 di Python, pertanto diviene:

    python2 ciao.py

    oppure semplicemente:

    python ciao.py
  • Andando a inserire la direttiva #!/usr/bin/env python3 come nel secondo metodo, anch'essa dovrà essere rapportata a Python 2, quindi:

    #!/usr/bin/env python2

    oppure semplicemente:

    #!/usr/bin/env python

Guide di approfondimento

  • Listati Python 2: esempi script esemplificativi presenti in alcuni programmi scritti in Python 2 a difficoltà crescente.

  • Listati Python 3: esempi script esemplificativi presenti in alcuni programmi scritti in Python 3 a difficoltà crescente.

  • Pip: guida a pip, gestore di pacchetti per Python, utile per installare moduli, librerie, frameworks, vari software per sviluppo, ricerca scientifica, svago ecc.

  • Interfacce grafiche: esempi di alcuni programmi scritti in Python 2.7.xx con semplice interfaccia grafica.

  • Interfacce grafiche Python 3: esempi di alcuni programmi scritti in Python 3.x con semplice interfaccia grafica.

  • Glade: guida a Glade, strumento per creare interfacce grafiche in GTK+ compatibili con Python.

Guide per principianti

I seguenti testi (principalmente in inglese) sono indicati per chiunque si voglia avvicinare per la prima volta a un linguaggio di programmazione.

Python 2

Python 3

Ulteriori risorse


CategoryProgrammazione