Python intermédiaire pour les développeurs
Jasmin Ludolf
Curriculum Manager
def average(values): """Find the mean in a sequence of values and round to two decimal places.""" average_value = sum(values) / len(values) rounded_average = round(average_value, 2) return rounded_average# Using six arguments print(average(15, 29, 4, 13, 11, 8))
TypeError: average() takes 1 positional argument but 6 were given
Les docstrings permettent de clarifier l'utilisation des fonctions personnalisées
Les arguments arbitraires permettent aux fonctions d'accepter un nombre quelconque d'arguments
# Allow any number of positional, non-keyword arguments
def average(*args):
# Function code remains the same
Dénomination conventionnelle : *args
Permet une variété d'utilisations tout en produisant les résultats escomptés !
# Calling average with six positional arguments
print(average(15, 29, 4, 13, 11, 8))
13.33
* : Convertir les arguments en un seul itérable (tuple)# Calculating across multiple lists
print(average(*[15, 29], *[4, 13], *[11, 8]))
13.33
# Use arbitrary keyword arguments def average(**kwargs):average_value = sum(kwargs.values()) / len(kwargs.values()) rounded_average = round(average_value, 2) return rounded_average
Arguments de mots-clés arbitraires : **kwargs
keyword=value
# Calling average with six kwargs
print(average(a=15, b=29, c=4, d=13, e=11, f=8))
13.33
# Calling average with one kwarg
print(average(**{"a":15, "b":29, "c":4, "d":13, "e":11, "f":8}))
13.33
# Calling average with three kwargs
print(average(**{"a":15, "b":29}, **{"c":4, "d":13}, **{"e":11, "f":8}))
13.33
Python intermédiaire pour les développeurs