Задать вопрос

Регулярные выражения, отрицание слова?

Есть строка типа:

x1..........x2.............x8................x2

(вместо точек могут быть любые символы и пробелы).
Задача: выбрать x1, x2 наиболее близкие друг к другу.

То есть, если мы напишем /(x1)[\s\S]*(x2)/u то будут выбраны x1 и x2 который стоит в конце строки, мне же нужно чтобы был выбран x2 который стоит ближе к x1.
Логически предположить, что для этого нужно добавить условие, чтобы между выбранными x1 и x2 не было других x1 и x2 тогда они самые ближние друг к другу, пробовал:
/(x1)(?!x2|x1)(x2)/u
Не работает, но это и логично так как такая регулярка не предусматривает наличие символов между переменными.
  • Вопрос задан
  • 3022 просмотра
Подписаться 1 Оценить Комментировать
Помогут разобраться в теме Все курсы
  • Skillbox
    Веб-разработчик на PHP
    9 месяцев
    Далее
  • Хекслет
    PHP-разработчик
    10 месяцев
    Далее
  • Нетология
    Веб-разработчик с нуля: профессия с выбором специализации
    14 месяцев
    Далее
Пригласить эксперта
Ответы на вопрос 1
Всего-то и нужно, что уменьшить жадность квантификатора:
/(x1)[\s\S]*?(x2)/u
Посмотреть пример
Ответ написан
Ваш ответ на вопрос

Войдите, чтобы написать ответ

Похожие вопросы
FoodSoul Калининград
от 180 000 до 250 000 ₽
IT-Spirit Москва
от 230 000 до 320 000 ₽
от 200 000 до 290 000 ₽