Как использовать multiline как group-separator в grep?

В grep вы можете использовать --group-separator чтобы писать что-то между групповыми совпадениями.

Это полезно, чтобы дать понять, какие блоки у нас есть, особенно при использовании опции -CX для получения контекстных строк.

  • Значение Grep из json-файла
  • Как использовать grep / awk / unix для соответствия всем строкам из одного файла в другом файле, даже если они дублируются
  • Поиск всех xml-файлов рекурсивно в каталоге для определенного тега и grep значение тега
  • Липкие записи в истории оболочки
  • Как правильно выполнить grep на выходе ldd?
  • В форме `exec FD>` exec
  •  $ cat a hello this is me and this is something else hello hello bye i am done $ grep -C1 --group-separator="+++++++++" 'hello' a hello this is me +++++++++ something else hello hello bye 

    Я научился использовать пустую строку как контекст «group-separator» для grep, как просто иметь пустую строку, говоря --group-separator="" .

    Однако, что, если я хочу иметь две пустые строки? Я попробовал сказать – --group-separator="\n\n" но я получаю литерал \n s:

     $ grep -C1 --group-separator="\n\n" 'hello' a hello this is me \n\n something else hello hello bye 

    Другие вещи, такие как --group-separator="\nhello\n" тоже не работали.

  • Почему я не могу использовать эту команду для командной строки?
  • find + grep для соответствия точных ключевых слов в файле
  • Вставка строки в файл только в том случае, если эта строка еще не является частью файла
  • добавьте «#» в начале выбранных строк в файле
  • Почему grep ищет больше, чем файлы, которые я хочу со звездочкой?
  • Почему echo "a"] "| grep -E "\" не соответствует?
  • 2 Solutions collect form web for “Как использовать multiline как group-separator в grep?”

    Ooooh Я нашел его, мне просто нужно использовать синтаксис $'' вместо $"" :

     $ grep -C1 --group-separator=$'\n\n' 'hello' a hello this is me something else hello hello bye 

    От man bash :

    квотирование

    Слова формы $ 'string' обрабатываются специально. Слово расширяется до строки с заменой символов с обратным слэшем, как указано в стандарте ANSI C. Последующие последовательности обратной косой черты, если они имеются, декодируются следующим образом:

     (...) \n new line 

    Я предлагаю использовать echo -e или printf с \\n для новой строки.

    Пример (с echo -e ):

     $ grep -C1 --group-separator="$(echo -e line1\\n\\nline2)" 'hello' a hello this is me line1 line2 something else hello hello bye 

    Пример (с printf ):

     $ grep -C1 --group-separator="$(printf hello\\nfedorqui)" 'hello' a hello this is me hello fedorqui something else hello hello bye 

    Одно из преимуществ заключается в использовании двойной кавычки . (следовательно, переменное расширение и т. д.)

    Linux и Unix - лучшая ОС в мире.