Last Updated : 23 Jul, 2025
Introduced in Python 3.10, the match case statement offers a powerful mechanism for pattern matching in Python. It allows us to perform more expressive and readable conditional checks. Unlike traditional if-elif-else chains, which can become unwieldy with complex conditions, the match-case statement provides a more elegant and flexible solution.
Example: Python
def check_number(x):
match x:
case 10:
print("It's 10")
case 20:
print("It's 20")
case _:
print("It's neither 10 nor 20")
check_number(10)
check_number(30)
Explanation:
Let's take a look at python match case statement in detail:
Python Match Case Statement Syntax
The match-case syntax is based on structural pattern matching, which enables matching against data structures like sequences, mappings and even classes, providing more granularity and flexibility in handling various conditions. This feature is particularly useful when dealing with different types of data in a clear and organized manner.
match subject:
case pattern1:
# Code block if pattern1 matches
case pattern2:
# Code block if pattern2 matches
case _:
# Default case (wildcard) if no other pattern matches
Now, let us see a few examples to know how the match case statement works in Python.
The power of the match-case statement lies in its ability to match a variety of data types, including constants, sequences, mappings and custom classes. Let's explore how to use match-case with different data types.
Match Case Statements with ConstantsMatching constants is one of the simplest uses of the match-case statement. It checks if a variable matches specific constant values and allows for different actions based on the matched constant.
Python
def greet(person):
match person:
case "A":
print("Hello, A!")
case "B":
print("Hello, B!")
case _:
print("Hello, stranger!")
greet("A")
greet("B")
Explanation:
The match-case statement can also be used with logical operators like or to combine multiple patterns. This allows for a more flexible matching system where you can group patterns and check for a match against any of them.
Example:
Python
def num_check(x):
match x:
case 10 | 20 | 30: # Matches 10, 20, or 30
print(f"Matched: {x}")
case _:
print("No match found")
num_check(10)
num_check(20)
num_check(25)
Explanation:
We can also add an if condition after a case to create more granular control over the matching process. This allows us to add additional checks within a case.
Example:
Python
def num_check(x):
match x:
case 10 if x % 2 == 0: # Match 10 only if it's even
print("Matched 10 and it's even!")
case 10:
print("Matched 10, but it's not even.")
case _:
print("No match found")
num_check(10)
num_check(15)
Explanation:
The match-case statement is particularly powerful when working with sequences such as lists or tuples. We can match individual elements of a sequence or even match the structure of the sequence itself.
Example:
Python
def process(data):
match data:
case [x, y]:
# A list with two elements
print(f"Two-element list: {x}, {y}")
case [x, y, z]:
# A list with three elements
print(f"Three-element list: {x}, {y}, {z}")
case _:
print("Unknown data format")
process([1, 2])
process([1, 2, 3])
process([1, 2, 3, 4])
Explanation:
A mapping is another common data type in Python and match-case can be used to match against dictionaries, checking for specific keys and values.
Python
def person(person):
match person:
# Dictionary with name and age keys
case {"name": name, "age": age}:
print(f"Name: {name}, Age: {age}")
# Dictionary with only name key
case {"name": name}:
print(f"Name: {name}")
case _:
print("Unknown format")
person({"name": "Alice", "age": 25})
person({"name": "Bob"})
person({"city": "New York"})
Explanation:
One of the most powerful features of match-case is the ability to match against classes. We can match instances of a class and even extract specific attributes of an object for further handling.
Example:
Python
class Shape:
pass
class Circle(Shape):
def __init__(self, radius):
self.radius = radius
class Rectangle(Shape):
def __init__(self, width, height):
self.width = width
self.height = height
def check_shape(shape):
match shape:
# Match Circle and extract the radius
case Circle(radius):
print(f"circle radius {radius}.")
# Match Rectangle and extract width and height
case Rectangle(width, height):
print(f"Rectangle width {width} and height {height}.")
# Default case for any other object
case _:
print("This is an unknown shape.")
# Create objects of Circle and Rectangle
circle = Circle(10)
rectangle = Rectangle(4, 6)
# Test with different shapes
check_shape(circle)
check_shape(rectangle)
Explanation:
RetroSearch is an open source project built by @garambo | Open a GitHub Issue
Search and Browse the WWW like it's 1997 | Search results from DuckDuckGo
HTML:
3.2
| Encoding:
UTF-8
| Version:
0.7.4