![Получить все совпадения регулярных выражений между двумя шаблонами и вывести их в файл](https://rvso.com/image/50567/%D0%9F%D0%BE%D0%BB%D1%83%D1%87%D0%B8%D1%82%D1%8C%20%D0%B2%D1%81%D0%B5%20%D1%81%D0%BE%D0%B2%D0%BF%D0%B0%D0%B4%D0%B5%D0%BD%D0%B8%D1%8F%20%D1%80%D0%B5%D0%B3%D1%83%D0%BB%D1%8F%D1%80%D0%BD%D1%8B%D1%85%20%D0%B2%D1%8B%D1%80%D0%B0%D0%B6%D0%B5%D0%BD%D0%B8%D0%B9%20%D0%BC%D0%B5%D0%B6%D0%B4%D1%83%20%D0%B4%D0%B2%D1%83%D0%BC%D1%8F%20%D1%88%D0%B0%D0%B1%D0%BB%D0%BE%D0%BD%D0%B0%D0%BC%D0%B8%20%D0%B8%20%D0%B2%D1%8B%D0%B2%D0%B5%D1%81%D1%82%D0%B8%20%D0%B8%D1%85%20%D0%B2%20%D1%84%D0%B0%D0%B9%D0%BB.png)
У меня есть файл с кучей длинных строк. Я хотел бы захватить каждую группу между двумя шаблонами и вывести их в новый файл, по одному совпадению на строку. Я мог бы сделать это с помощью Python, но я бы предпочел использовать только инструменты командной строки для этой задачи. Если шаблона конца нет, я бы хотел захватить все до конца строки.
Что-то вроде:
input:
xxSTART relevanttext xxEND something else xxSTART even more relevant
output:
relevanttext
even more relevant
решение1
ЕСЛИ GNU grep является опцией, вы можете передать -P
флаг (регулярное выражение, совместимое с Perl) и использовать утверждения просмотра вперед, утверждения просмотра назад и нежадные совпадения, чтобы извлечь то, что вам нужно.
echo 'xxSTART relevanttext xxEND something else xxSTART even more relevant' |\
grep -oP '(?<=START).*?(?=xxEND|$)'
relevanttext
even more relevant
Или, как предлагает Стефан Шазелас, используйте изящную\Квместо утверждения о взгляде назад
echo 'xxSTART relevanttext xxEND something else xxSTART even more relevant' |\
grep -oP 'START\K.*?(?=xxEND|$)'