![Fichier:Python logo and wordmark.svg — Wikipédia](https://upload.wikimedia.org/wikipedia/commons/thumb/f/f8/Python_logo_and_wordmark.svg/1200px-Python_logo_and_wordmark.svg.png)
Une fonction (ou méthode), est un bloc d'instructions réutilisable. Si vous venez à réécrire plusieurs fois les mêmes lignes dans votre code, cela signifie que vous pouvez les mettre sous forme de fonction. Votre code sera alors beaucoup plus lisible.
## Déclarer une fonction
Une fonction se déclare avec le mot-clé "def" et nécessite une identation.
Il suffira ensuite d'appeler la fonction par son nom.
```python
#Déclaration de la fonction
def print_something_useless():
print("Il fait beau aujourd'hui")
#Appel de la fonction
print_something_useless()
>>> Il fait beau aujourd'hui
```
## Les arguments
Une fonction peut demander des arguments. Ce sont des variables à renseigner lors de l'appel de la fonction permettant son execution.
```python
def divide_numbers(dividende,diviseur):
quotient = dividende/diviseur
print(quotient)
divide_numbers(4,2)
>>> 2
```
Il est possible d'attribuer une valeur par défaut à un argument. Celle-ci sera remplacée si on précise une valeur.
```python
def divide_numbers(dividende,diviseur=3):
quotient = dividende/diviseur
print(quotient)
divide_numbers(9) #cas 1 : valeur par défaut
divide_numbers(9,9) #cas 2 : nouvelle valeur
>>> 3 #cas 1
>>> 1 #cas 2
```
### Récupérer le résultat d'une fonction
Il est important de noter que toutes les variables d'une focntion sont locales. Une fois l'éxecution de la fonction terminée, toutes ses variables sont effacées. Dans l'exemple précédent il aurait pu être intéressant de récupérer le résultat de la division pour la suite de notre script.
Pour ce faire on utilise le mot-clé ***return***.
Ensuite, on attribue l'appel de la fonction à une ou plusieurs variables.
Le décorateur est une fonction permettant de modifier le comportement d'autres fonctions, évitant la répétition de code. Il est appelé par “ @nom\_décoraeur ”.
```python
def title_decorator(function):
def wrapper(*args, **kwargs):
print("*"*30)
print("-"*30)
function(*args, **kwargs)
print("-"*30)
print("*"*30)
return wrapper
@title_decorator
def title(titre):
print(titre)
>>> titre = "Ceci est mon texte décoré"
>>> title(titre)
******************************
------------------------------
Ceci est mon texte décoré
------------------------------
******************************
```
Ce décorateur permet simplement de mettre en forme un titre. Mais le décorateur, critiqué pour son nom ne définissant pas assez clairement sa fonction, peut avoir bien d'autres usages.
Par exemple, dans le cadre du _développement web_, les décorateurs sont très utilisés. Typiquement, pour les pages nécessitant une authentification, le décorateur “ @login\_required ” du framework Django est très utile.
```python
from django.contrib.auth.decorators import login_required
@login_required
def my_page(request):
...
```
Tout comme “ @login\_required ”, beaucoup de décorateurs sont déjà développés, nécessitant un simple import.