Оператор match/case в Python 3.10+ — основы структурного сопоставления

19 июня 2026
Автор

Антон Ларичев

Введение

Начиная с Python 3.10, в языке появился оператор структурного сопоставления с образцом — match/case. Он позволяет сравнивать значение с набором шаблонов и выполнять соответствующий блок кода. Это не просто замена цепочки if/elif/elsematch/case умеет деструктурировать данные, проверять типы и выполнять сложное сопоставление.

В этой статье мы разберём базовый синтаксис match/case, покажем как работать с литералами, переменными и подстановочным символом _, а также сравним новый оператор с классическим if/elif.

Базовый синтаксис match/case

Оператор match принимает выражение и последовательно проверяет его по шаблонам в блоках case. Как только найдено совпадение, выполняется соответствующий блок кода, а остальные шаблоны пропускаются.

# Базовый пример match/case
def get_status_message(code):
    match code:
        case 200:
            return "OK"
        case 404:
            return "Не найдено"
        case 500:
            return "Внутренняя ошибка сервера"
        case _:
            return f"Неизвестный код: {code}"

# Вызов функции
print(get_status_message(200))   # OK
print(get_status_message(404))   # Не найдено
print(get_status_message(418))   # Неизвестный код: 418

Здесь _ — это подстановочный шаблон (wildcard), который совпадает с любым значением. Он работает аналогично блоку else в конструкции if/elif/else.

Сопоставление с литералами

Самый простой случай — сопоставление с конкретными значениями: числами, строками, булевыми значениями и None.

# Сопоставление со строковыми литералами
def handle_command(command):
    match command:
        case "start":
            print("Запуск программы")
        case "stop":
            print("Остановка программы")
        case "restart":
            print("Перезапуск программы")
        case "help":
            print("Доступные команды: start, stop, restart, help")
        case _:
            print(f"Неизвестная команда: {command}")

handle_command("start")    # Запуск программы
handle_command("quit")     # Неизвестная команда: quit
# Сопоставление с None и булевыми значениями
def check_value(value):
    match value:
        case None:
            print("Значение отсутствует")
        case True:
            print("Истина")
        case False:
            print("Ложь")
        case _:
            print(f"Другое значение: {value}")

check_value(None)    # Значение отсутствует
check_value(True)    # Истина
check_value(42)      # Другое значение: 42

Захват значения в переменную

Если в шаблоне case указать имя без кавычек и не являющееся литералом, Python привяжет совпавшее значение к этой переменной.

# Захват значения в переменную
def describe_number(value):
    match value:
        case 0:
            print("Ноль")
        case n:
            # Переменная n захватывает любое значение
            print(f"Число: {n}, квадрат: {n ** 2}")

describe_number(0)   # Ноль
describe_number(5)   # Число: 5, квадрат: 25

Важно помнить, что переменная-захват совпадает с любым значением, поэтому её стоит ставить последней — иначе до остальных шаблонов дело не дойдёт.

Объединение шаблонов через оператор OR

Оператор | позволяет объединять несколько шаблонов в одном case. Если значение совпадёт хотя бы с одним из них, блок будет выполнен.

# Объединение шаблонов через |
def classify_day(day):
    match day:
        case "понедельник" | "вторник" | "среда" | "четверг" | "пятница":
            return "Рабочий день"
        case "суббота" | "воскресенье":
            return "Выходной"
        case _:
            return "Неизвестный день"

print(classify_day("среда"))       # Рабочий день
print(classify_day("суббота"))     # Выходной
# Объединение числовых шаблонов
def http_category(code):
    match code:
        case 200 | 201 | 204:
            return "Успех"
        case 301 | 302:
            return "Перенаправление"
        case 400 | 401 | 403 | 404:
            return "Ошибка клиента"
        case 500 | 502 | 503:
            return "Ошибка сервера"
        case _:
            return "Неизвестный код"

print(http_category(201))   # Успех
print(http_category(403))   # Ошибка клиента

Если вы хотите детальнее изучить Python и его современные возможности — приходите на наш большой курс Python-разработчик с нуля. На курсе 210 уроков и 150 упражнений, AI-тренажёры для практики 24/7, решение задач с живым ревью наставника, еженедельные встречи с менторами.

Сравнение match/case с if/elif/else

Рассмотрим одну и ту же логику, записанную через if/elif и через match/case.

# Вариант с if/elif/else
def get_color_if(color):
    if color == "red":
        return "#FF0000"
    elif color == "green":
        return "#00FF00"
    elif color == "blue":
        return "#0000FF"
    else:
        return None

# Вариант с match/case
def get_color_match(color):
    match color:
        case "red":
            return "#FF0000"
        case "green":
            return "#00FF00"
        case "blue":
            return "#0000FF"
        case _:
            return None

В простых случаях match/case выглядит чище и читабельнее. Однако главное его преимущество проявляется при работе со сложными структурами данных — деструктуризацией кортежей, списков и объектов. Об этом мы расскажем в отдельной статье.

Важные особенности

Стоит знать несколько особенностей оператора match/case:

  • Порядок шаблонов важен — Python проверяет шаблоны сверху вниз и выполняет первый совпавший
  • Нет fall-through — в отличие от switch в C/Java, после выполнения совпавшего блока остальные не проверяются
  • Шаблон _ не обязателен — если ни один шаблон не совпал, ничего не происходит
  • Переменная-захват перезаписывает — если в текущей области видимости уже есть переменная с таким именем, она будет перезаписана
# Демонстрация перезаписи переменной
x = 10
match 42:
    case x:
        # x теперь равен 42, а не 10!
        print(f"x = {x}")

print(f"x после match = {x}")  # x после match = 42

Частые ошибки

  • Использование переменной вместо литерала — если написать case status_ok: вместо case 200:, Python не сравнит значение с переменной status_ok, а создаст новую привязку. Для сопоставления с константами используйте точечную нотацию: case http.HTTPStatus.OK:
  • Забытый подстановочный шаблон — без case _: при отсутствии совпадений не произойдёт ничего, что может быть неочевидным поведением
  • Использование match/case в Python ниже 3.10 — оператор доступен только начиная с Python 3.10, в более ранних версиях вы получите SyntaxError

Частозадаваемые вопросы

Можно ли использовать match/case в Python 3.9 и ниже? Нет, оператор match/case доступен только начиная с Python 3.10 (PEP 634). Для более ранних версий используйте цепочку if/elif/else или словарь с маппингом.

Чем match/case отличается от switch/case в других языках? В отличие от switch в C, Java или JavaScript, оператор match/case в Python — это полноценное структурное сопоставление с образцом (pattern matching). Он умеет деструктурировать данные, проверять типы и формы объектов, а не только сравнивать с конкретными значениями.

Влияет ли match/case на производительность? Для простых случаев производительность match/case сопоставима с цепочкой if/elif. Преимущество проявляется в читаемости кода и при работе со сложными структурами данных.

Заключение

Оператор match/case в Python 3.10+ — это мощный инструмент для управления потоком выполнения программы. В базовом варианте он заменяет цепочку if/elif/else, делая код чище и выразительнее. Подстановочный шаблон _ обеспечивает обработку случаев по умолчанию, а оператор | позволяет объединять несколько шаблонов.

Для закрепления навыков работы с Python и его современными возможностями рекомендуем курс Python-разработчик с нуля. В первых 3 модулях курса доступно бесплатное содержание, что позволяет разобраться в основах языка и понять структуру курса до покупки полного доступа.

Стрелочка влевоОсновные методы Python и примеры их использованияПаттерны match/case в Python — деструктуризация, guard и вложенные шаблоныСтрелочка вправо

Постройте личный план изучения Python до уровня Middle — бесплатно!

Python — часть карты развития Backend

  • step100+ шагов развития
  • lessons30 бесплатных лекций
  • lessons300 бонусных рублей на счет

Все гайды по Python

Как отправлять запросы с помощью requests в PythonКак работает команда print в PythonПочему Python выводит значение без команды printВозможности Python для автоматизации задачPython get — методы получения данныхРабота с JSON в Python на примерахКак находить и исправлять ошибки в PythonРабота с данными через API и внешние сервисыСтруктура и оформление кода PythonОсновы Django с PythonПолезные приёмы в Python для повседневной работыИспользование locals в Python для отладкиИнтеграция PHP и PythonКак выполнять HTTPS-запросы в PythonКак работать с API в PythonFastAPI Python — быстрый старт: создание REST API с нуля
Ввод целого числа в PythonВедение логов в PythonУдаление данных в Python с помощью removeОбработка исключений с помощью try/except в PythonФункция super() в Python — как вызвать метод родителяСоздание собственных контекстных менеджеров в PythonРабота с символами программирования PythonРабота с переменной X в PythonРабота с классами в PythonПростая программа на Python для начинающихКак скачать Python на компьютерОсновы Python для тех, кто начинаетЧто нового в Python 3Поддерживается ли Python 2 и стоит ли его использоватьPython 1 — с чего начиналась история языкаКоманда python print - полное руководство по выводу данныхПравила именования переменных в PythonПользовательские исключения в PythonОсновы Python coreОписание объектов PythonНаследование классов в Python — основы и примерыМножественное наследование в Python — примеры и MROКонтекстный менеджер with в Python — как работает и зачем нуженКомментарии в Python — однострочные, многострочные и docstringКакой Python выбрать для установкиКак вывести целое число с помощью print в PythonКак установить Python на Windows macOS и LinuxКак пользоваться консолью PythonКак получить последний элемент в PythonКак найти значение в PythonКак настроить PythonКак использовать print для строк в PythonКак работает интерпретатор PythonИнструкция по работе с PythonБлок finally в обработке исключений PythonЦелые числа в PythonАбстрактные классы в Python — ABC и abstractmethod
Загрузка данных PythonУправление проектами на GitHub с PythonСоздание веб-приложений на Flask PythonСоздание бота на PythonСоздание интерфейсов Python QTСоздание игр с PygameСоздание GUI в PythonКак работать со словарями в PythonРабота с библиотеками через Python PackagingРабота со временем в Python при помощи модуля timePython name — особенности переменнойМатематические операции в Python с модулем mathPython listing — что это и как использоватьPytest — тестирование на Python: полное руководствоОбработка изображений с OpenCV PythonNumPy в Python — основы и применение в задачахМашинное обучение с PythonИспользование Anaconda с PythonМодуль contextlib в Python — утилиты для контекстных менеджеровБиблиотеки Python и их применение в проектах
Возврат значений из функции в PythonВложенные функции в PythonСоздание собственных декораторов в PythonРабота с функцией map в PythonЦикл while в Python и примеры использованияОсновные операторы в Python с примерамиОбработка чисел, введённых через input в PythonУсловные выражения if else в Python для начинающихКак выполняется вызов функций call в PythonПродвинутые генераторы в Python — send, throw, close и корутиныПозиционные и именованные аргументы в PythonОбъявление переменных и управление областью видимости в PythonПередача аргументов по ссылке и по значению в PythonПередача аргументов через args и kwargs в PythonОсновные методы Python и примеры их использованияОператор match/case в Python 3.10+ — основы структурного сопоставленияПаттерны match/case в Python — деструктуризация, guard и вложенные шаблоныПрактические примеры match/case в Python — реальные сценарии примененияЛокальные и глобальные переменные в PythonЧасто используемые команды PythonКлючевые слова global и nonlocal в PythonКак создавать функции в PythonКак работает сборщик мусора в PythonКак работает область видимости переменных в PythonКак работает функция callable в PythonКак работает функция any и all в PythonКак проверить тип переменной в PythonКак передать функцию как аргумент в PythonКак использовать функцию isinstance в PythonКак использовать функцию filter в PythonКак использовать функцию filter в PythonКак использовать функцию eval безопасно в PythonКак использовать декораторы в PythonИзменяемые и неизменяемые типы данных в PythonГенераторы и yield в Python — как создавать и использоватьГенераторные выражения в Python — синтаксис и примерыФункции в Python и способы их вызоваФункции как объекты в PythonЧто такое замыкания в PythonЧто делает функция reduce в PythonЧто делает функция id в PythonАргументы по умолчанию в PythonАнонимные функции и lambda в PythonАлгоритмы на Python — примеры и объяснение
Запись данных в PythonУстановка pip в PythonУправление зависимостями requirement в PythonУправление библиотеками с помощью Python PackagingУдаление пробелов с помощью strip в PythonСтруктурирование кода в PythonСоздание исполняемого файла Python в exeРазбор traceback в модуле PythonРазбор site-packages в PythonРазбор Program Files в PythonРабота с Unicode кодировками в PythonРабота с системными функциями Python sysРабота с папкой AppData в PythonРабота с модулем logging в PythonРабота с каталогами в PythonРабота с CSV в PythonВиртуальная среда venv в Python — создание и настройкаКак создать простое приложение на PythonИспользование pip в Python для установки пакетовМодули в Python и организация кода в проектеИмпорт модулей в Python и правила подключенияРабота с файлами в Python пошаговоЧто делает компилятор Python и как он работаетПолучение строки из модуля PythonПодключение файлов в Python с includeПеременные среды в PythonСборка проекта с помощью packaging в PythonНастройка Python сервераИспользование Python на UbuntuИспользование консоли PythonИспользование кодировок в PythonИнициализация пакетов PythonИмпорт модулей PythonИмпорт имен в PythonСреда IDLE Python и базовые возможностиЧтение и запись TXT в PythonЧтение файлов в Python с помощью open file
Удаление элементов из списка PythonТипы данных в Python — обзор и рекомендацииОсновные операции со строками в PythonМетоды str в Python и обработка текстаСписки в Python и их ключевые методыСоздание списков данных в PythonРабота со строками и символами в PythonРабота со столбцами в PythonРабота со списком значений в PythonРабота с таблицами в Python с помощью DataFrameРабота с RFR в PythonРабота с пробелами в PythonРабота с массивами в PythonРабота с кортежами tuple PythonРабота с координатами X и Y в PythonРабота с ключами в PythonРабота с элементами данных PythonРабота с двоичными числами PythonРабота с данными в PythonРабота с данными NumPy PythonРабота с большими числами в PythonРабота с битами в PythonРабота с байтами в PythonЧто такое значение в Python и как его определитьМножества в Python и операции с нимиИспользование range в Python для цикловПроверка на четность в PythonПроверка числа в PythonПреобразование типов в PythonПреобразование списка в строку PythonПреобразование числа в строку в PythonПостроение графиков в PythonОпределение индекса элемента в PythonОкругление чисел в PythonОбъединение списков в Python с помощью zipМножества в PythonМассивы в Python и отличие от списковМассив чисел в PythonКортежи данных в PythonКак вычислить сумму чисел в PythonКак получить остаток от деления в PythonКак найти следующее число в PythonИспользование Unicode в PythonТип int в Python и его особенностиИндекс списка в PythonФункции для работы со строками в PythonЭлементы Python и способы доступа к нимДоступ к элементам массива в PythonДеление чисел в PythonРабота с данными в Python на практикеКак работать с числами в Python
Открыть базу знаний

Лучшие курсы по теме

Иконка молнииНовый
изображение курса

Основы Python

Антон Ларичев
AI-тренажерыAI-тренажеры
Практика в студииПрактика в студии
Гарантия
Бонусы
иконка звёздочки рейтинга4.7
3 999 ₽ 6 990 ₽
Подробнее
изображение курса

Nest.js с нуля

Антон Ларичев
AI-тренажерыAI-тренажеры
Практика в студииПрактика в студии
Гарантия
Бонусы
иконка звёздочки рейтинга4.6
3 999 ₽ 6 990 ₽
Подробнее
изображение курса

Docker и Ansible

Антон Ларичев
AI-тренажерыAI-тренажеры
Гарантия
Бонусы
иконка звёздочки рейтинга4.7
3 999 ₽ 6 990 ₽
Подробнее

Отправить комментарий