Grep: Difference between revisions

From NovaOrdis Knowledge Base
Jump to navigation Jump to search
 
(7 intermediate revisions by the same user not shown)
Line 22: Line 22:
</pre>
</pre>


=Regular Expressions=
=Options=
 
<pre>
^ - beginning of line


$ - end of line
==-q==


\t - tab
Quiet.


digits:
==-v, --invert-match==


:[0-9]*
Invert the sense of matching, to select non-matching lines.


:\d
==<tt>-e</tt>==


GNU grep uses <code>-e</code> to introduce a regular expression to match. Also see: {{Internal|Grep_Regular_Expressions|<tt>grep</tt> Regular Expressions}}


\. dot
=Regular Expressions=
</pre>
 
Characters that need and do not need escaping:


<blockquote style="background-color: #f9f9f9; border: solid thin lightgrey;">
{{Internal|grep Regular Expressions|grep Regular Expressions}}
:[[Sed_Regular_Expressions#Special_Characters_.28need_to_be_escaped_in_regular_expressions.29|sed: Special Characters (need to be escaped in regular expressions)]]
 
:[[Sed_Regular_Expressions#Non-Special_Characters_.28do_not_need_to_be_escaped_in_regular_expressions.29|sed: Non-Special Characters (do not need escaping in regular expressions)]]
</blockquote>


=Recipes=
=Recipes=
Line 105: Line 96:
-m 1
-m 1
</pre>
</pre>
==Print More Lines of Trailing Context after Each Match==
Use -A to print a number of lines of trailing context after each match:
grep -A 10 "something" ./file.txt
==Iterate over Lines Selected by grep==
<syntaxhighlight lang='bash'>
IFS="$(printf '\n\r')";
for i in $(grep "something ${some_file}); do
  ...
done
IFS="$(printf ' \t\n')"
</syntaxhighlight>
See also: {{Internal|Bash_Built-In_Variables#IFS|IFS}}

Latest revision as of 23:41, 29 March 2024

Internal

Overview

grep accepts regular expressions. Both " " and ' ' can be used to enclose the expression to search for.

If the expression is found, the enclosing lines are sent to stdout the command returns 0 (success).

If the expression is NOT found, the command returns 1 (failure).


    if grep -q "some regex" ./file.txt; then
        # do something if expression is found
    else
        # do something else if the expression is not found
    fi

Options

-q

Quiet.

-v, --invert-match

Invert the sense of matching, to select non-matching lines.

-e

GNU grep uses -e to introduce a regular expression to match. Also see:

grep Regular Expressions

Regular Expressions

grep Regular Expressions

Recipes

Including TWO expressions at the same time

cat /proc/cpuinfo | grep 'processor\|siblings'

processor	: 0
siblings	: 2
processor	: 1
siblings	: 2

The method works even if there are spaces and other regular expression characters within the alternative regexes:

... | grep ' logger: [1-9]\+\.\|(concurrent mode failure)'

This will select either "logger: [1-9]\+\." or "(concurrent mode failure)"

Excluding TWO expressions at the same time

     echo "something" | grep -v "blah" | grep -v "blah2"

Do not Send Anything to stout

... and avoid > /dev/null:

    grep -q

--color

grep --color 'context.layer='

Prefix the Line with the "Line Number" (-n)

-n prefixes the line with the line number.

sed: Insert a Line/Append in a Specific Position (line number) in a file

Return Only the First Match

-m means "stop reading the file about num matches. So to return the first match:

-m 1

Print More Lines of Trailing Context after Each Match

Use -A to print a number of lines of trailing context after each match:

grep -A 10 "something" ./file.txt

Iterate over Lines Selected by grep

IFS="$(printf '\n\r')";
for i in $(grep "something ${some_file}); do
  ...
done
IFS="$(printf ' \t\n')"

See also:

IFS