Skip to main content

Match Case Statement in Python

 


Learning Sections     show

Match-Case Statements

In Python 3.10 and later, the match-case statement was introduced as a way to perform pattern matching, similar to switch-case statements in other programming languages. It allows you to check the value of a variable against multiple patterns and execute corresponding blocks of code.

Basic Match-Case Statement

The match statement is followed by an expression and several case clauses. Each case specifies a pattern and an action to be taken if the pattern matches the value of the expression.


# Basic match-case statement example
command = "start"

match command:
    case "start":
        print("Starting...")
    case "stop":
        print("Stopping...")
    case "pause":
        print("Pausing...")
    case _:
        print("Unknown command")
    

Matching Multiple Patterns

Using the pipe symbol |, you can match multiple patterns in a single case clause.


# Matching multiple patterns example
status = "open"

match status:
    case "open" | "opened":
        print("The status is open.")
    case "closed" | "shut":
        print("The status is closed.")
    case _:
        print("Unknown status")
    

Using Guards in Case Clauses

Guards allow you to add additional conditions to a case clause using the if keyword.


# Using guards in case clauses example
number = 42

match number:
    case x if x >> 0:
        print("The number is positive")
    case x if x == 0:
        print("The number is zero")
    case x if x < 0:
        print("The number is negative")
    

Pattern Matching with Data Structures

The match-case statement can also be used to match patterns in data structures like lists and tuples.


# Pattern matching with lists example
data = [1, 2, 3]

match data:
    case [1, 2, 3]:
        print("Matched [1, 2, 3]")
    case [4, 5, 6]:
        print("Matched [4, 5, 6]")
    case _:
        print("No match")
    

# Pattern matching with tuples example
point = (4, 5)

match point:
    case (0, 0):
        print("The point is at the origin")
    case (x, y):
        print(f"The point is at ({x}, {y})")
    

Popular posts from this blog

Introduction to OOPs in Python

  Learning Sections          show Introduction to Object-Oriented Programming (OOP) Object-Oriented Programming (OOP) is a programming paradigm that organizes software design around objects rather than actions and data rather than logic. It revolves around the concept of "objects", which are instances of classes. These objects encapsulate data, in the form of attributes or properties, and behaviors, in the form of methods or functions. OOP promotes modularity, reusability, and extensibility in software development. Key Concepts of OOP: Class: A class is a blueprint or template for creating objects. It defines the attributes (data) and methods (functions) that will characterize any object instantiated from that class. Object: An object is an instance of a class. It is a concrete realization of the class blueprint, containing actual values instead of placeholders for attributes. Encapsulation: Encapsulation is ...

Inheritance in Python

  Learning Sections          show Inheritance in Python Inheritance is a fundamental concept in object-oriented programming (OOP) that allows a class to inherit attributes and methods from another class. The class that inherits is called the child class or subclass, and the class being inherited from is called the parent class or superclass. Basic Inheritance In Python, a child class inherits from a parent class by specifying the parent class in parentheses after the child class name. Example: class Animal : def __init__ ( self , name ): self . name = name def speak ( self ): raise NotImplementedError ( "Subclass must implement this method" ) class Dog ( Animal ): def speak ( self ): return "Woof!" class Cat ( Animal ): def speak ( self ): return "Meow!" # Create instances of Dog and Cat dog = Dog ( "Buddy" ) cat = Cat ( "Whiskers" ...

AsyncIO in Python

  Learning Sections          show AsyncIO in Python AsyncIO is a library to write concurrent code using the async/await syntax. It allows you to manage asynchronous tasks and I/O operations in Python. Basics of AsyncIO AsyncIO provides an event loop, coroutines, and tasks: Event loop: The core of every asyncio application. It runs asynchronous tasks and callbacks. Coroutines: Special functions defined with async def . They use await to pause their execution and wait for other coroutines. Tasks: Used to schedule coroutines to run concurrently in the event loop. Creating a Simple Coroutine import asyncio # Define a coroutine async def say_hello (): print ( "Hello" ) await asyncio.sleep ( 1 ) print ( "World" ) # Create an event loop and run the coroutine asyncio.run ( say_hello ()) Running Multiple Coroutines import asyncio async de...