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

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

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

 $ 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" тоже не работали.

  • Чтобы удалить лишнее пространство из строки с помощью команды оболочки
  • fstab не монтирует cifs при запуске
  • Как временно обходить псевдоним в tcsh?
  • Как переименовать неназванные файлы с соответствующими расширениями?
  • Инкрементная арифметика Sed
  • Как классифицировать эти строки в этом файле ASCII
  • Как добавить комментарии к многострочным операторам в сценарии Bash?
  • Запуск нескольких программ в фоновом режиме и проверка их возвращаемого значения
  • 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 - лучшая ОС в мире.