Для сохранения прогресса вступите в курс. Войти или зарегистрироваться.

Конспект урока

Регулярные выражения поддерживают поиск по условию. Пожалуй, это одна из самых сложных конструкций, которая существует в регулярных выражениях. Она напоминает тернарный оператор из языков программирования и выглядит следующим образом:


/(?(?<=a)m|p)

mam,pap


Мы видим внешние скобки с ?, а внутри - два отдельных выражения:

  • Первое — это условие (?<=a), которое проверяет, соответствует ли символ слева a.
  • Дальше идет альтернатива, и мы выбираем между m и p в зависимости от того, сработало условие или нет.

Давайте разберем поиск в нашей строке посимвольно:

  • первый символ m не соответствует a, поэтому следующий символ проверяется на соответствие p, что тоже не дает совпадения;
  • второй символ a соответствует a, поэтому следующий символ проверяется на соответствие m;
  • третий символ m соответствует m — найдено первое сопоставление;
  • четвертый символ , не соответствует a, поэтому следующий символ проверяется на соответствие p;
  • пятый символ p соответствует p — найдено второе сопоставление;
  • шестой символ a снова запускает проверку следующего символа на соответствие m;
  • седьмой символ p проваливает проверку на соответствие m.

Вот так в результате условного поиска у нас было найдено два совпадения в строке.

NB! Условный поиск не поддерживается в JavaScript и многих других языках программирования. В некоторых языках нужно учитывать особенности его реализации: Python поддерживает условный поиск с использованием группировки с обратной связью или именованных групп.

Полезные ссылки

Мы учим программированию с нуля до стажировки и работы. Попробуйте наш бесплатный курс «Введение в программирование» или полные программы обучения по Node, PHP, Python и Java.

Хекслет

Подробнее о том, почему наше обучение работает →