egrep "foo|bar" *.txt
lub
grep "foo\|bar" *.txt
grep -E "foo|bar" *.txt
wybiórczo powołując się na stronę man gnu-grep:
-E, --extended-regexp
Interpret PATTERN as an extended regular expression (ERE, see below). (-E is specified by POSIX.)
Matching Control
-e PATTERN, --regexp=PATTERN
Use PATTERN as the pattern. This can be used to specify multiple search patterns, or to protect a pattern
beginning with a hyphen (-). (-e is specified by POSIX.)
(...)
grep understands two different versions of regular expression syntax: “basic” and “extended.” In GNU grep, there
is no difference in available functionality using either syntax. In other implementations, basic regular
expressions are less powerful. The following description applies to extended regular expressions; differences for
basic regular expressions are summarized afterwards.
Na początku nie czytałem dalej, więc nie rozpoznałem subtelnych różnic:
Basic vs Extended Regular Expressions
In basic regular expressions the meta-characters ?, +, {, |, (, and ) lose their special meaning; instead use the
backslashed versions \?, \+, \{, \|, \(, and \).
Zawsze używałem egrep i niepotrzebnie parens, ponieważ uczyłem się na przykładach. Teraz nauczyłem się czegoś nowego. :)