| Contenus | Capacités attendues | Commentaires | 
|---|---|---|
| p-uplets. p-uplets nommés | Écrire une fonction renvoyant un p-uplet de valeurs. | 
Dans la deuxième partie 2-Représentation des données: types et
valeurs de base, nous avions vu certains types de
variables simples: int(entiers), float(nombres à virgule
flottante) bool(booléen), str(châine de caractères)
Nous allons maintenant voir des types construits qui sont des collections d'objets de type simple assemblés dans ce que l'on appelle une structure de données.
Nous verrons dans cette partie trois exemples de types construits:
tuple et listes list: des collections d'éléments
ordonnés dans lesquels les valeurs sont accédées via un index de
position.namedtuple et les dictionnaires dict:
ensemble d'éléments dans lesquels les valeurs sont accédées via une
clef.Nous commencons dans ce premier chapitre par les tuples, très utilisés
notamment lorsque l'on souhaite travailler avec plusieurs variables
simultanément.
Les tuples sont des valeurs séparées par des virgules , entourées de
parenthèses (..., ..., ...)` qui peuvent parfois être ommises.
Entrée
(1, 2, 3)Résultat
(1, 2, 3)Entrée
# sans parenthèses
1, 2, 3Résultat
(1, 2, 3)Entrée
type((1, 2, 3))Résultat
tupleOn peut stocker plusieurs valeurs de types différents dans une variable de type tuple.
Entrée
t = (1, 2.0, "trois")
tRésultat
(1, 2.0, 'trois')Entrée
type(t)Résultat
tupleL'accès se fait par un index entier de position qui commence à 0. On place l'index entre des crochets.
Entrée
t[0]Résultat
1Entrée
t[1]Résultat
2.0Entrée
t[2]Résultat
'trois'ATTENTION: Dans les types construits, il faut bien distinguer l'index et la valeur stockée à cet index.
Les tuples présentent de nombreuses méthodes qui sont décrites dans la
documentation
ou grâce à l'appel help(tuple)
len: nombre d'éléments stockés.index: index de l'élément cherché donné en argument.count: nombre d'éléments de valeur donnée en argument.La différence entre méthode et fonction sera approfondie en terminale lors de l'étude de la programmation orientée objet. Pour l'instant nous pouvons simplement dire qu'il s'agit d'une fonction attachée à un objet qui s'appelle en utilisant une notation pointée.
# appel d'une fonction
fonction(arguments)
# appel d'une méthode d'objet
objet.méthode(arguments)Entrée
print(t)Sortie
(1, 2.0, 'trois')Entrée
len(t)Résultat
3Entrée
t.index(-3)-------------------------------------------------------------------------
ValueError                              Traceback (most recent call last)
<ipython-input-11-1ab9b8c50e8f> in <module>
----> 1 t.index(-3)
ValueError: tuple.index(x): x not in tupleEntrée
t.count(10)Il peut être pratique de récupérer les valeurs stockées dans le tuple dans des variables de type simple: on parle de déstructuration.
Entrée
a, b, c = t
print("t=", t)
print("a=", a)
print("b=", b)
print("c=", c)Habituellement, lorsque l'on souhaite pemuter deux variables, il est nécessaire de passer par une troisième variable auxiliaire. Grâce aux tuples, la permutation peut se faire en une instruction.
Entrée
a = 3
b = 2
print("a=",a, "b=", b)
print("Permutation")
a, b = b, a
print("a=",a, "b=", b)Sortie
a= 3 b= 2
Permutation
a= 2 b= 3Il s'agit d'une application courante des tuples. prenons l'exemple d'une fonction qui renvoie les deux racines du trinome.
Entrée
def racines_du_trinome(a,b,c):
    delta = b**2-4*a*c
    if delta > 0:
        return -b-delta**0.5/(2*a), -b+delta**0.5/(2*a)
racines_du_trinome(1,0,-1)Résultat
(-1.0, 1.0)Ici on récupère les racines par déstructuration.
Entrée
x1, x2 = racines_du_trinome(1,0,-2)
print("racine 1:", x1)
print("racine 2:", x2)Sortie
racine 1: -1.4142135623730951
racine 2: 1.4142135623730951Les tuples peuvent stocker n'importe quel type de valeurs.
Entrée
(False, "un", 2.0, 3)Résultat
(False, 'un', 2.0, 3)Les tuples sont immutables, c'est à dire qu'on ne peut les modifier une fois qu'ils ont été créés.
Entrée
t[0] = 6-------------------------------------------------------------------------
TypeError                               Traceback (most recent call last)
<ipython-input-17-28b8e5df48e8> in <module>
----> 1 t[0] = 6
TypeError: 'tuple' object does not support item assignmentIl est possible de créer des p-uplets nommés afin de pouvoir accéder aux éléments de la collection par clé.
Ce type nécessite d'être importé par le module collections avant
d'être utilisé.
Entrée
from collections import namedtuple
Eleve = namedtuple('Eleve', 'nom, age, classe, spécialité')
e = Eleve("John", 17, "1g", "nsi" )
eRésultat
Eleve(nom='John', age=17, classe='1g', spécialité='nsi')L'avantage de l'accès par clef est qu'il apporte plus d'expressivité au code.
L'accès peut se faire en ajoutant un point et le nom de la clé. Il s'agit encore d'une notation pointée comme dans le cas d'appel de méthodes, cependant il n'y a pas de parenthèses car il s'agit de valeurs et non de fonctions(On parle d'attributs de l'objet).
Entrée
e.ageRésultat
17Entrée
e.spécialitéRésultat
'nsi'L'usage des p-uplet qu'ils soient nommés ou pas reste peu répandu au
profit des tableaux list et dictionnaires dict respectivement, qui
au contraire des n-uplets sont
mutables.
On pourra ainsi y ajouter des éléments, en retirer...