В чем смысл (^ |) ABC (| $) как расширенного REGEX?

Я пришел сюда через команду grep -E '(^ ​​|) ABC (| $)' file1. Я смущен, как интерпретировать в ней регулярное выражение, потому что я знаю символы ^ и $ как начальные и конечные обозначения, но здесь они не в самом начале или конце из-за скобки, иногда используется для отрицания набора символов, но я видел это использование только в [^ ….] как выражение.

Может ли кто-нибудь объяснить шаг за шагом значение этого регулярного выражения?

  • Почему комбинация tail + grep + cut не работает?
  • Удалить слово после матча
  • Что означает выражение Grep?
  • Соответствие двух файлов для аналогичной первой строки
  • Как я могу рекурсивно искать каталоги для шаблона и просто распечатывать имена файлов и номера строк
  • linux + соответствует IP ADDRESS с 3 октетами или с 4 октетами
  • Список (или перемещение) только файлов с определенным количеством строк?
  • Рисунок Grep и шаблон в шаблоне
  • One Solution collect form web for “В чем смысл (^ |) ABC (| $) как расширенного REGEX?”

    Это означает, что grep должен искать строку ABC только в начале строки ИЛИ после пробела, причем эта строка должна заканчиваться другим пробелом ИЛИ концом строки.

    Другими словами, кто-то хотел найти строки, которые образуют целые слова . Однако это регулярное выражение имеет много проблем, а может быть много других символов до и после слова (по крайней мере, на естественном языке), т. Е. ( , ) . , ; , : ,,, ... и т. д.

    Таким образом, лучше использовать -w вариант grep , альтернативно играть с границами: \b или \< / \> .

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