Module: Sous-routines (Python) : Procédures et fonctions - 1


Problem

1/11

Sous-programmes : introduction

Theory Click to read/hide

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 !
  1. 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).
  2. Toutes les instructions exécutées dans une procédure sont en retrait. 
  3. 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 !
  4. Vous pouvez appeler une procédure dans un programme autant de fois que vous le souhaitez.

Problem

Écrivez une procédure qui affiche la phrase "Erreur. Division par zéro! Donnez le nom correct à la procédure.