grep Command

Thursday, June 26, 20089comments

Syntax

grep [ -E -F ] [ -i ] [ -h ] [ -H ] [ -L ] [ -r -R ] [ -s ] [ -v ] [ -w ] [ -x ] [ -y ] [ [ [ -b ] [ -n ] ] [
-c -l -q ] ] [ -p [ Separator ] ] { [ -e PatternList ... ] [ -f PatternFile ... ] PatternList ... } [ File ...
]

Description

The grep command searches for the pattern specified by the Pattern parameter and writes each matching line to
standard output. The patterns are limited regular expressions in the style of the ed or egrep command. The grep
command uses a compact non-deterministic algorithm.

The grep command displays the name of the file containing the matched line if you specify more than one name in the
File parameter. Characters with special meaning to the shell ($, *, [, , ^, (, ), \ ) must be in quotation marks
when they appear in the Pattern parameter. When the Pattern parameter is not a simple string, you usually must
enclose the entire pattern in single quotation marks. In an expression such as [a-z], the - (minus sign) cml
specifies a range, according to the current collating sequence. A collating sequence may define equivalence classes
for use in character ranges. If no files are specified, grep assumes standard input.

Notes:
1 Paragraphs (under the -p flag) are currently limited to a length of 5000 characters.
2 Do not run the grep command on a special file because it produces unpredictable results.
3 Input lines should not contain the NULL character.
4 Input files should end with the newline character.
5 The newline character will not be matched by the regular expressions.
6 Although some flags can be specified simultaneously, some flags override others. For example, the -l option
takes precedence over all other flags. And if you specify both the -E and -F flags, the last one specified
takes priority.

Flags

-b
Precedes each line by the block number on which it was found. Use this flag to help find disk block numbers by
context. The -b flag cannot be used with input from stdin or pipes.

-c
Displays only a count of matching lines.

-E
Treats each pattern specified as an extended regular expression (ERE). A NULL value for the ERE matches every
line.

Note: The grep command with the -E flag is the same as the egrep command, except that error and usage messages
are different and the -s flag functions differently.


-e PatternList
Specifies one or more search patterns. This works like a simple pattern but is useful when the pattern begins with a - (minus). Patterns should be separated by a new-line character. A NULL pattern can be specified by two adjacent new-line characters or a quotation mark followed by a new-line character ("\n). Each pattern is treated like a basic regular expression (BRE) unless the -E or -F flag is also specified. Multiple -e and -f flags are accepted by grep. All of the specified patterns are used when matching lines, but the order of evaluation is unspecified.

-F
Treats each specified pattern as a string instead of a regular expression. A NULL string matches every line.

Note: The grep command with the -F flag is the same as the fgrep command, except that error and usage messages are different and the -s flag functions differently.

-f PatternFile
Specifies a file containing search patterns. Each pattern should be separated by a new-line character, and an empty line is considered a NULL pattern. Each pattern is treated like a basic regular expression (BRE), unless the -E or -F flag is also specified.

-h
Prevents the name of the file containing the matching line from being appended to that line. Suppresses file names when multiple files are specified.

-H
If the -r or -R option is specified and a symbolic link referencing a file of type directory is specified on the command line, grep will search the files of the directory referenced by the symbolic link and all the files in the file hierarchy below it.

-i
Ignores the case (uppercase or lowercase) of letters when making comparisons.


-l
Lists just the names of files (once) which contain matching lines. Each file name is separated by a new-line character. If standard input is searched, a path name of (StandardInput) is returned. The -l flag with any combination of the -c and -n flags behaves like the -l flag only.

-L
If the -r or -R option is specified and a symbolic link referencing a file of type directory is specified on the command line or encountered during the traversal of a file hierarchy, grep shall search the files of the directory referenced by the symbolic link and all the files in the file hierarchy below it. If both -H and -L are specified, the last option specified on the command line takes effect.

-n
Precedes each line with the relative line number in the file. Each file starts at line 1, and the line counter is reset for each file processed.

-p[Separator]
Displays the entire paragraph containing matched lines. Paragraphs are delimited by paragraph separators, as specified by the Separator parameter, which are patterns in the same form as the search pattern. Lines containing the paragraph separators are used only as separators; they are never included in the output. The default paragraph separator is a blank line.

-q
Suppresses all writing to standard output, regardless of matching lines. Exits with a zero status if an input line is selected. The -q flag with any combination of the -c, -l and -n flags behaves like the -q flag only.

-r
Searches directories recursively. By default, links to directories are followed.

-R
Searches directories recursively. By default, links to directories are not followed.

-s
Suppresses error messages ordinarily written for nonexistent or unreadable files. Other error messages are not suppressed.

-v
Displays all lines not matching the specified pattern.

-w
Does a word search.

-x
Displays lines that match the specified pattern exactly with no additional characters.

-y
Ignores the case of letters when making comparisons. PatternList Specifies one or more patterns to be used during the search. The patterns are treated as if they were specified using the -e flag.
File Specifies a name of a file to be searched for patterns. If no File variable is given, the standard input is used.

Examples
1 To use a pattern that contains some of the pattern-matching characters *, ^, ?, [, ], \(, \), \{, and \},
enter:

grep "^[a-zA-Z]" pgm.s

This displays every line in pgm.s whose first character is a letter.
2 To display all lines that do not match a pattern, enter: grep -v "^#" pgm.s

This displays every line in pgm.s whose first character is not a # (pound sign).

3 To display all lines in the file1 file that match either the abc or xyz string, enter: grep -E "abcxyz" file1

4 To search for a $ (dollar sign) in the file named test2, enter:

grep \\$ test2

The \\ (double backslash) characters are necessary in order to force the shell to pass a \$ (single backslash, dollar sign) to the grep command. The \ (single backslash) character tells the grep command to treat the following character (in this example the $) as a literal character rather than an expression character. Use the fgrep command to avoid the necessity of using escape characters such as the backslash.

5 To search recursively through /tmp to find files which have the word IBM without recursing through links pointing to directories, type:

grep -R IBM /tmp
OR

grep -r -H IBM /tmp
6 To search recursively through /tmp to find files which have the word IBM and recurse through links as well,
type:

grep -r IBM /tmp
OR

grep -R -L IBM /tmp

Files

/usr/bin/grep
Contains the grep command.
Share this article :

+ comments + 9 comments

Anonymous
July 2, 2017 at 10:42 PM

SAP BASIS training is provided in CHENNAI.

THE CREATING EXPERTS is one of the leading trainer in SAP who provides real time training

http://thecreatingexperts.com/sap-basis-training-in-chennai/

contact 8122241286

Anonymous
July 14, 2017 at 6:05 AM

Nice blog....For a long time I was looking for SAP BASIS training in Chennai and got the link


THE CREATING EXPERTS is providing SAP BASIS training in real time

http://thecreatingexperts.com/sap-basis-training-in-chennai/

Contact 8122241286

Anonymous
July 15, 2017 at 4:13 AM

SAP BASIS training is provided in CHENNAI.I personally got trained with them one of the best trainers in CHENNAI

THE CREATING EXPERTS is one of the leading trainer in SAP who provides real time training

http://thecreatingexperts.com/sap-basis-training-in-chennai/

contact 8122241286

July 21, 2017 at 2:02 AM

Informative post...for a long time I was searching for a trainer in Chennai

And i landed with THE CREATING EXPERTS one of the leading trainer with real time training in Chennai

http://thecreatingexperts.com/sap-basis-training-in-chennai/

contact 8122241286 for more info.

July 22, 2017 at 2:06 AM

SAP BASIS training is provided by THE CREATING EXPERTS

If you are looking for a real time trainer then take a look at the mail below

http://thecreatingexperts.com/sap-basis-training-in-chennai/

contact 8122241286

July 24, 2017 at 2:32 AM

SAP BASIS training is provided by THE CREATING EXPERTS

If you are looking for a real time trainer then take a look at the mail below

http://thecreatingexperts.com/sap-basis-training-in-chennai/

contact 8122241286

Anonymous
July 27, 2017 at 7:27 AM

SAP basis training by THE CREATING EXPERTS

http://thecreatingexperts.com/sap-basis-training-in-chennai/

contact 8122241286 for more info.

If you are looking for SAP basis here is a real time trainer to get trained from.

Anonymous
July 28, 2017 at 9:10 AM

Creating experts, A leading career development organization with live examples by corporate Experts.

SAP training by online and classroom training is provided

http://thecreatingexperts.com/sap-basis-training-in-chennai/


Contact 8122241286 SAP basis training in chennai

Anonymous
July 30, 2017 at 2:06 AM

The Information you provided is very much useful for SAP Learners. This Information was very Interesting,

SAP training in Chennai by THE CREATING EXPERTS for SAP BASIS, take a look at the link below

http://thecreatingexperts.com/sap-basis-training-in-chennai/

contact 8122241286 for more info.

Post a Comment
 
Support : Basis SAP | Basis SAP | Basis SAP
Copyright © 2011. Basis SAP - All Rights Reserved
Template Created by Basis SAP Published by Basis SAP
Proudly powered by Blogger