difference between positional and keyword arguments

1. Positional Arguments

How they work: The arguments you pass are matched to the function’s parameters based solely on their order (i.e., their position). The first argument is assigned to the first parameter, the second to the second, and so on.

Example:

python

def describe_pet(animal_type, pet_name):
    """Display information about a pet."""
    print(f"\nI have a {animal_type}.")
    print(f"My {animal_type}'s name is {pet_name}.")

# Positional argument passing
describe_pet('hamster', 'Harry')

Output:

text

I have a hamster.
My hamster's name is Harry.
  • 'hamster' (1st argument) is assigned to animal_type (1st parameter).
  • 'Harry' (2nd argument) is assigned to pet_name (2nd parameter).

What happens if you mess up the order?
You get logical errors that can be hard to debug.

python

describe_pet('Harry', 'hamster') # Oops! Wrong order.

Output:

text

I have a Harry.
My Harry's name is hamster. # This is nonsense.

2. Keyword Arguments

How they work: You explicitly name each argument when you call the function using the syntax parameter_name=value. This means the order of the arguments does not matter.

Example:

python

def describe_pet(animal_type, pet_name):
    """Display information about a pet."""
    print(f"\nI have a {animal_type}.")
    print(f"My {animal_type}'s name is {pet_name}.")

# Keyword argument passing
describe_pet(animal_type='hamster', pet_name='Harry')
describe_pet(pet_name='Harry', animal_type='hamster') # Order doesn't matter!

Output (for both calls):

text

I have a hamster.
My hamster's name is Harry.

Why use them?

  1. Clarity: It’s immediately clear what each value represents.
  2. Flexibility: You can specify arguments in any order.
  3. Skipping Defaults: They are essential when you want to use a default value for an early parameter but provide an argument for a later one.

3. Mixing Positional and Keyword Arguments

You can mix both styles in a single function call, but there is one strict rule:

Positional arguments must come before any keyword arguments.

Example:

python

def describe_pet(animal_type, pet_name, age):
    """Display information about a pet."""
    print(f"\nI have a {animal_type} named {pet_name}. It is {age} years old.")

# Valid: Two positional, one keyword
describe_pet('hamster', 'Harry', age=3)

# Valid: One positional, two keyword
describe_pet('hamster', pet_name='Harry', age=3)
describe_pet('hamster', age=3, pet_name='Harry') # Order of keywords doesn't matter

# INVALID: Keyword before positional
# describe_pet(animal_type='hamster', 'Harry', 3) # This will cause a SyntaxError

4. Practical Example: The print() Function

The built-in print() function is a perfect example of these concepts in action. Its signature looks conceptually like this:
print(*objects, sep=' ', end='\n', file=sys.stdout, flush=False)

  • *objects: Takes any number of positional arguments.
  • sependfileflush: Are all keyword-only parameters with default values.

python

# Using only positional arguments
print('Hello', 'World', '!') # Output: Hello World !

# Using a mix of positional and keyword arguments
print('Hello', 'World', sep='-') # Output: Hello-World
print('Hello', end=' ') # Changes the end character from newline to a space
print('World')           # Output: Hello World (on the same line)

Summary & Key Differences

FeaturePositional ArgumentsKeyword Arguments
BasisOrder (Position)Name (Keyword)
Syntaxfunction(value1, value2)function(param1=value1, param2=value2)
Order ImportanceCritical. Wrong order causes errors.Irrelevant. Order doesn’t matter.
ClarityLess clear. You must know the parameter order.Very clear. Acts as built-in documentation.
Use CaseFor required parameters where the meaning is obvious (e.g., add(x, y)).For optional parameters, parameters with defaults, or to improve readability.
Rule in a CallMust be listed before keyword arguments.Must be listed after positional arguments.

Best Practice: For functions with more than two or three parameters, or parameters that aren’t immediately obvious, use keyword arguments to make your code self-documenting and much easier to read and maintain.

Similar Posts

  • recursive function

    A recursive function is a function that calls itself to solve a problem. It works by breaking down a larger problem into smaller, identical subproblems until it reaches a base case, which is a condition that stops the recursion and provides a solution to the simplest subproblem. The two main components of a recursive function…

  • Python Program to Check Pangram Phrases

    Python Program to Check Pangram Phrases What is a Pangram? A pangram is a sentence or phrase that contains every letter of the alphabet at least once. Method 1: Using Set Operations python def is_pangram_set(phrase): “”” Check if a phrase is a pangram using set operations “”” # Convert to lowercase and remove non-alphabetic characters…

  • pop(), remove(), clear(), and del 

    pop(), remove(), clear(), and del with 5 examples each, including slicing where applicable: 1. pop([index]) Removes and returns the item at the given index. If no index is given, it removes the last item. Examples: 2. remove(x) Removes the first occurrence of the specified value x. Raises ValueError if not found. Examples: 3. clear() Removes all elements from the list, making it empty. Examples: 4. del Statement Deletes elements by index or slice (not a method, but a…

  • Curly Braces {} ,Pipe (|) Metacharacters

    Curly Braces {} in Python Regex Curly braces {} are used to specify exact quantity of the preceding character or group. They define how many times something should appear. Basic Syntax: Example 1: Exact Number of Digits python import re text = “Zip codes: 12345, 9876, 123, 123456, 90210″ # Match exactly 5 digits pattern = r”\d{5}” # Exactly…

  • Predefined Character Classes

    Predefined Character Classes Pattern Description Equivalent . Matches any character except newline \d Matches any digit [0-9] \D Matches any non-digit [^0-9] \w Matches any word character [a-zA-Z0-9_] \W Matches any non-word character [^a-zA-Z0-9_] \s Matches any whitespace character [ \t\n\r\f\v] \S Matches any non-whitespace character [^ \t\n\r\f\v] 1. Literal Character a Matches: The exact character…

  • Formatted printing

    C-Style String Formatting in Python Python supports C-style string formatting using the % operator, which provides similar functionality to C’s printf() function. This method is sometimes called “old-style” string formatting but remains useful in many scenarios. Basic Syntax python “format string” % (values) Control Characters (Format Specifiers) Format Specifier Description Example Output %s String “%s” % “hello” hello %d…

Leave a Reply

Your email address will not be published. Required fields are marked *