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

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

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

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

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

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

Войти через центр авторизации
Похожие вопросы