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

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

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

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 Оценить Комментировать
Помогут разобраться в теме Все курсы
  • Skillfactory
    Профессия Fullstack веб-разработчик на JavaScript и PHP
    20 месяцев
    Далее
  • Хекслет
    PHP-разработчик
    10 месяцев
    Далее
  • Skillbox
    PHP-разработчик. Базовый уровень
    3 месяца
    Далее
Пригласить эксперта
Ответы на вопрос 1
Всего-то и нужно, что уменьшить жадность квантификатора:
/(x1)[\s\S]*?(x2)/u
Посмотреть пример
Ответ написан
Ваш ответ на вопрос

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

Похожие вопросы