Sous-programmes
Une sous-routine est une partie distincte du programme qui a un nom et résout sa propre tâche distincte. Le sous-programme est situé au début du programme principal et peut être lancé (appelé) à partir du programme principal en spécifiant le nom.
L'utilisation de sous-programmes vous permet d'éviter la duplication de code, si vous devez écrire le même code à différents endroits du programme.
Les bibliothèques importées dans un programme (par exemple, la bibliothèque mathématique math) sont constituées de sous-programmes qui ont déjà été compilés par quelqu'un. Les programmeurs n'ont pas besoin de réfléchir aux algorithmes qu'ils implémentent, mais simplement de les appliquer, en pensant uniquement à ce qu'ils font exactement. C'est un gain de temps considérable. Il n'est pas nécessaire d'écrire un algorithme qui a déjà été écrit par quelqu'un d'autre.
Chaque sous-programme
ne doit effectuer qu'une seule tâche,  ; soit simplement calculer quelque chose, soit générer des données, soit faire autre chose.
Il existe deux types de sous-programmes : les
procédures et les
fonctions.
Les sous-procédures effectuent certaines actions, telles que l'affichage d'un résultat à l'écran sous une certaine forme (un exemple simple, l'instruction
print()
est une sous-procédure standard qui imprime des données à l'écran).
Les sous-routines de fonctions
retournent un résultat (nombre, chaîne de caractères, etc.) que nous pouvons utiliser dans le programme principal.
Essayons d'écrire une procédure simple :
Supposons que nous ayons besoin d'afficher la chaîne "Erreur" à l'écran chaque fois qu'une erreur peut se produire dans le code en raison de la faute de l'utilisateur, par exemple lorsqu'il saisit des données incorrectes.
Cela peut être fait en écrivant l'opérateur
print("Erreur")
Et maintenant, imaginez qu'une telle ligne doive être insérée à de nombreux endroits dans le programme. Bien sûr, vous pouvez simplement l'écrire partout. Mais cette solution a deux inconvénients.
1) Cette chaîne sera stockée en mémoire plusieurs fois.
2) Si nous voulons changer la sortie en cas d'erreur, nous devrons changer cette ligne tout au long du programme, ce qui est plutôt gênant
Dans de tels cas, des procédures sont nécessaires.
Un programme avec une procédure pourrait ressembler à ceci :
def printError() : # description de la procédure
print("Erreur")
...
printError() # lance la procédure d'exécution.
# Spécifiez simplement le nom de la procédure que nous voulons exécuter
...
impressionErreur()
Ne pas oublier !
- La procédure commence par le mot
def
(de l'anglais - define - à définir). Après le nom de la procédure, des crochets vides et deux-points sont écrits . Les paramètres peuvent être spécifiés entre parenthèses (nous en reparlerons plus tard).
- Toutes les instructions exécutées dans une procédure sont en retrait.
- Pour exécuter une procédure, dans le programme principal, vous devez l'appeler par son nom et n'oubliez pas d'écrire des parenthèses !
- Vous pouvez appeler une procédure dans un programme autant de fois que vous le souhaitez.