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

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

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

  • Могу ли я взять вывод ldd и загрузить файлы .so?
  • / bin / etc / lib64 / root / sbin удалены или перемещены папкой mv / * / *, в то время как su
  • аннотировать файл «include» для grep с комментариями?
  • если команда find -exec
  • Как использовать grep для трубы |
  • Перехватывать и изменять команды в сценариях bash
  •  $ 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" тоже не работали.

  • Как переместить некоторые, но не все файлы из одного каталога в другой?
  • Как перебирать переменную, пропуская одно из значений?
  • Греп от конца файла до начала
  • Почему новые линии испортили мое состояние?
  • Найти все слова, начинающиеся с Q
  • команда терминала | grep IP
  • 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 - лучшая ОС в мире.