Grep Article Index for
Grep
 

Information About

Grep




grep is a Command Line utility that was originally written for use with the Unix operating system. Given a list of files or Standard Input to read, grep searches for lines of text that match one or many Regular Expression s, and outputs only the matching lines.


FUNCTION AND USAGE

The name, "grep", derives from the command used to perform a similar operation, using the Unix text editor Ed :

:g/''re''/p

which means "search globally for lines matching the '''r'''egular '''e'''xpression, and '''p'''rint them". There are various command line switches available when using grep that modify this default behavior including printing lines which do ''not'' match, finding or excluding files to search, and annotating the output in various ways. There are also multiple, modern implementations of the classic Unix grep, each with a unique feature set.

This is an example of a common grep usage:

:grep apple fruitlist.txt

Grep would return, in this case, all of the lines in file fruitlist.txt with an instance of 'apple' in them. Keep in mind that grep would not return lines with 'Apple' (capital A) because by default grep is case sensitive. Like most Unix commands grep accepts flags which can be used to change this and many other behaviors. For example:

:grep -i apple fruitlist.txt

This would return all lines with the words 'apple', 'Apple', 'apPLE', or any other mixing of capital and lower case.

The option -e can also be used to declare multiple patterns for searching on the command line with some versions of grep.


VARIATIONS

There are many derivatives of grep, for example Agrep which stands for ''approximate grep'' to facilitate Fuzzy String Searching , fgrep for fixed pattern searches, and '''egrep''' for searches involving more sophisticated regular expression syntax.
fgrep and egrep are typically the same program as grep, which behaves differently depending on the name by which it is invoked. Tcgrep is a rewrite of grep which uses Perl Regular Expression syntax. All these variations of grep have been ported to many computer operating systems.

Many other commands contain the word "grep." Pgrep , for instance, displays the processes whose names match a regular expression.

In Perl , grep is a built-in function, which when provided both a Regular Expression (or a general code block) and a list, returns the elements of that list matched by the expression. In Functional Programming languages, this Higher-order Function is typically named "filter" instead.

The Microsoft Windows platform provides a utility called "findstr" which approximates much of the functionality of "grep."


USAGE AS A CONVERSATIONAL VERB

As the name "grep" neatly fits the grepped his Usenet spool for his name." Compare with '' Google ''. Sometimes ''visual grep'' is used as a term meaning to look through text searching for something, in the manner of the grep program.

In December 2003, the '' Oxford English Dictionary Online'' added draft entries for "grep" as both a noun and a verb.

A common usage is the phrase "You can't grep dead trees" - meaning computerized documentation is better than printed documentation (paper is made from dead trees) because computers can search documents by using tools such as grep.

The word "grep" has also become a synonym for regular expressions themselves. Many text and word processors now employ regular expression search features, which those applications will often refer to as a "grep tool" or "grep mode" in which one creates "grep patterns", causing confusion, especially in non-Unix environments.


EGREP AND FGREP

Early variants of grep included egrep and fgrep. The former applies an extended regular expression syntax that was added to Unix after Ken Thompson 's original regular expression implementation. The latter simply reads a set of fixed strings to search for from a file. These early variants are embodied in most modern grep implementations as simple command-line switches (e.g. -E and -F respectively in GNU grep).


SEE ALSO




REFERENCES

  • 1

  • Andrew Hume. Grep wars: The strategic search initiative. In Peter Collinson, editor, ''Proceedings of the EUUG Spring 88 Conference'', pages 237–245, Buntingford, UK, 1988. European UNIX User Group.

  • 2



EXTERNAL LINKS