Files
python/concepts/function-arguments/introduction.md
BethanyG 185fbdfac9 Random grammar, spelling and content edits. (#3581)
[no important files changed]
2023-12-27 06:02:10 -08:00

2.2 KiB

Introduction

For the basics on function arguments, please see the function concept.

Parameter Names

Parameter names, like variable names, must start with a letter or underscore and may contain letters, underscores, or numbers. Parameter names should not contain spaces or punctuation.

Positional Arguments

Positional arguments are values passed to a function in the same order as the parameters which bind to them. Positional arguments can optionally be passed by using their parameter name.

Following is an example of positional arguments being passed by position and by their parameter name:

>>> def concat(greeting, name):
...         return f"{greeting}{name}"
... 
# Passing data to the function by position.
>>> print(concat("Hello, ", "Bob"))
Hello, Bob
... 
# Passing data to the function using the parameter name.
>>> print(concat(name="Bob", greeting="Hello, "))
Hello, Bob

The first call to concat passes the arguments by position. The second call to concat passes the arguments by name, allowing their positions to be changed.

Note that positional arguments cannot follow keyword arguments.

This

>>> print(concat(greeting="Hello, ", "Bob"))

results in this error:

SyntaxError: positional argument follows keyword argument

Keyword Arguments

Keyword arguments use the parameter name when calling a function. Keyword arguments can optionally be referred to by position.

Following is an example of keyword arguments being referred to by their parameter name and by position:

>>> def concat(greeting="Hello, ", name="you"):
...         return f"{greeting}{name}"
... 
# Function call using parameter names as argument keywords.
>>> print(concat(name="Bob", greeting="Hello, "))
Hello, Bob
...
# Function call with positional data as arguments.
>>> print(concat("Hello, ", name="Bob"))
Hello, Bob
>>> print(concat())
Hello, you