チップス

grep はパターンにマッチする行を表示する便利なコマンドです


grep は、「UNIXプログラミング環境」でも紹介されているコマンドで、32ページに

これはファイルを検索して、あるパターンに一致した行を探してくれるコマンドである。(その名前の由来は、ed コマンドの g/regular-expression/p であり、これについては付録1に説明がある。)

と書かれています。

プログラムのソースを調べたり、サーバ管理の為にログを解析したり環境変数を調べる時に良く使います。
man grep でgrepの使い方を調べてみましょう。

名称
grep, egrep, fgrep, zgrep - パターンにマッチする行を表示する

書式
grep [options] PATTERN [FILE...]
grep [options] [-e PATTERN | -f FILE] [FILE...]

解説
grep は、 FILE で名前を指定された入力ファイル (ファイルが指定されてないか、 file の部分に - が指定された場合は標準入力) を読み込み、与えられたPATTERN にマッチする部分を含む行を探します。デフォルト動作では、 grepはマッチした行を表示します。さらに、2 つのプログラム egrep と fgrep を利用可能です。 egrep はgrep -E と同じです。 fgrep は grep -F と同じです。 zgrep は grep -Z と同じです。

オプション
-A NUM, --after-context=NUM
NUM で指定した行数だけ、パターンにマッチした行の後の行も表示します。

-a, --text
バイナリファイルをテキストファイルであるかのように処理します。これは --binary-files=text オプションと等価です。

-B NUM, --before-context=NUM
NUM で指定した行数だけ、パターンにマッチした行の前の行も表示します。

-C [NUM], -NUM, --context[=NUM]
NUM で指定した行数 (デフォルトは 2) だけ、パターンにマッチした行の前後の行も表示します。

-b, --byte-offset
各出力行の前に、入力ファイルの先頭からのバイト単位のオフセットを表示します。

--binary-files=TYPE
ファイルの最初の数バイトが、ファイルの内容がバイナリファイルであることを示す場合、ファイルのタイプを TYPE であると仮定します。デフォルトでは TYPE は binary であり、 grep は通常、バイナリファイルの一致を示す一行メッセージを表示するか、マッチしない場合にはなに も表示しません。 TYPE が without-match の場合、 grep はバイナリファイルはマッチしないものと仮定します。これは -I オプションと等価です。 TYPE が text の場合、 grep はバイナリファイルをテキストであるかのように扱います。これは -a オプションと等価です。 警告: grep --binary-files=text はバイナリのゴミを表示する可能性があります。出力先が端末である場合で、端末ドライバがこのゴミの一部をコマンドであると解釈する場合、このゴミが悪い副作用をおよぼす可能性があります。

-c, --count
通常の出力はせず、各入力ファイルについてマッチした行数を表示します。 -v, --invert-match オプションと共に指定した場合は、マッチしなかった行数を表示します (下記参照)。

-d ACTION, --directories=ACTION
入力ファイルがディレクトリの場合に、 ACTION を使ってその処理を行います。デフォルトでは ACTION は read であり、ディレクトリを普通のファイルであるかの様に読み取る事を意味します。 ACTION が skip な ら、ディレクトリを黙って読み飛ばします。 ACTION が recurse なら、 grep は各ディレクトリ下のすべてのファイルを再帰的に読み取ります。これは -r オプションと等価です。

-E, --extended-regexp
PATTERN を拡張された正規表現として扱います (下記参照)。

-e PATTERN, --regexp=PATTERN
PATTERN をパターンとして指定します。 - で始まるパターンを保護するために有効です。

-F, --fixed-strings
PATTERN を改行で区切られた固定文字列のリストとして扱います。その文字列のどれかとマッチするかを調べます。

-f FILE, --file=FILE
パ ターンを FILE から 1 行ごとに読み込みます。空のファイルはパターンを含まないので、何にもマッチしません。

-G, --basic-regexp
PATTERN を基本的な正規表現として扱います (下記参照)。デフォルトです。

-H, --with-filename
各々のマッチに対してファイル名を表示します。

-h, --no-filename
複数ファイルを検索した時に、出力の前にファイル名を付けることを抑制します。

--help 簡単なヘルプメッセージを出力します。

-I バイナリファイルをマッチするデータを含まないかのように処理します。これは --binary-files=without-match オプションと等価です。

-i, --ignore-case
PATTERN と入力ファイルの双方で、英大文字と小文字の区別をしないようにします。

-L, --files-without-match
通常の出力はせず、このオプションを指定しなかったときに全く出力されない入力ファイルの名前を表示します。スキャン動作は最初のマッチで終了します。

-l, --files-with-matches
通常の出力はせず、このオプションを指定しなかったときに出力される入力ファイルの名前を表示します。スキャン動作は最初のマッチで終了します。

--mmap 可能ならば、デフォルトの read(2) システムコ ー ル の 代 わ り に mmap(2) システムコールを使って入力を読み取ります。ある状況において、 --mmap はよりよい性能をもたらします。しかし、 grep の動作中に 入力ファイルが小さくなるか、または I/O エラーが生じた場合に、 --mmap は (コアダンプを含む) 未定義の動作を引き起こす可能性が あります。

-n, --line-number
各出力行の前に、入力ファイルにおける行番号を表示します。

-q, --quiet, --silent
沈黙。通常の出力を抑止します。スキャン動作は最初のマッチで終了します。下記の -s や --no-messages オプションも参照。

-r, --recursive
各ディレクトリ下のすべてのファイルを再帰的に読み取ります。これは -d recurse オプションと等価です。

-s, --no-messages
指定されたファイルが存在しないことや読み込みできないことを示すエラーメッセージを抑止します。移植性に関する注: GNU grep とは異 なり 、伝統的な grep は POSIX.2 に適合していませんでした。なぜなら、伝統的な grep には -q オプションが無く、 -s オプション は GNU grep の -q オプションの様に動作したからです。伝統的な grep へ移植可能であることを意図したシェルスクリプトは、 -q と -s を両方とも使わずに、出力を /dev/null へリダイレクトすべきです。

-U, --binary
フ ァイルをバイナリとして扱います。デフォルトでは、MS-DOS と MS-Windows 環境下で grep は、ファイルから読み取った最初の 32KB の内容を見て、ファイルタイプを推測します。 grep はファイルをテキストファイルと判断した場合、オリジナルのファイル内容から ( ^ と $ が使われている正規表現を正しく動作させるために ) CR 文字を取り除きます。 -U を指定すると、この当て推量を抑制し、すべてのファイルを読み取ってマッチ機構へそのまま渡します。もしファイルが各行の末尾に CR/LF の組みを持つテキストファイルなら、このオプションは正規表現を役に立たなくさせることがあるでしょう。このオプションは MS-DOS と MS-Windows 以外のプラットフォームでは効果がありません。

-u, --unix-byte-offsets
unix 形式のバイト単位オフセットを報告します。このスイッチを指定すると grep は、ファイルが unix 形式のテキストファイル、すなわち、 CR 文字が取り除かれたファイルであるかのごとくにバイト単位オフセットを報告します。このことは grep を Unix マシンで動作させたのと同じ結果を生成します。このオプションは -b オプションも使用しない限り効果がありません。 MS-DOS と MS-Windows 以外のプラットフォームでは効果がありません。

-V, --version
grep のバージョン番号を標準エラー出力に表示します。バグレポー トには、この番号を付記してください (下記参照)。

-v, --invert-match
結果を反転し、マッチしなかった行を選択します。

-w, --word-regexp
完全な語にマッチする行のみを選択します。マッチする部分文字列が行頭から始まっているか、単語構成文字以外の文字が前にあることがテストされます。同様に、マッチする部分文字列が行末まであるか、単語構成文字以外の文字が後にある必要があります。単語構成文字とは、レター・数字・アンダスコアです。

-x, --line-regexp
行全体と正確にマッチする行のみを選択します。

-y -i と同じ意味を持つ旧式のオプションです。

--null 通常ファイル名の後に続く文字の代わりにバイト 0 (ASCII NUL 文字) を出力します。例えば、 grep -l --null は各ファイル名の後に、通常の newline ではなくバイト 0 を出力します。このオプションを指定すると、 newline 等の例外的な文字を含むファイル名に直面した場合 でも 出力が明白になります。このオプションを find -print0, perl -0,sort -z, xargs -0 等のコマンドと共に使用すれば、任意のファイル名を 処理できます。ファイル名が newline 文字を含んでいても処理可能です。

-Z, --decompress
検索を開始する前に入力データを伸長します。このオプションは zlib ライブラリと共にコンパイルした場合のみ使用可能です。

正規表現
正規表現は、文字列の集合を表現するパターンの事です。数式表現と同様に、より小さな表現を組み合わせるさまざまな演算子を用いる事で、正規表現を 組み立てます。

grep は、「基本」正規表現と「拡張」正規表現の 2 種類の正規表現文法を扱う事ができます。 GNU grep では、どちらの正規表現文法も機能的な違いは あり ません。他の実装では、基本正規表現は拡張正規表現より能力が低くなっています。ここでは、拡張正規表現について説明します。基本正規表現との違 いは、その後に説明します。

正規表現の基本単位は、1 文字にマッチする正規表現です。レターと数字を含む多くの文字は、それ自身にマッチする正規表現です。また、特殊な意味を 持つ メタ文字も、その文字の前にバックスラッシュを付けると、その本来の文字にマッチするようになります。

[ と ] で囲まれた文字のリストは、そのリスト中に含まれるどれか 1 文字 にマッチします。ただし、リストの先頭がキャレット ^ の場合は、そのリストに含まれ ない文字にマッチします。例えば、正規表現 [0123456789] は数 字 1文字にマッチします。文字の範囲は最初と最後の文字をハイフン (‘-’) でつなぐことで指定できます。最後に、特定の名前を持つ文字クラスがあらかじめ 定義 さ れ て い ま す 。 名 前 が内容を示しており、それらは、 [:alnum:],[:alpha:], [:cntrl:], [:digit:], [:graph:], [:lower:], [:print:],[:punct:], [:space:], [:upper:], [:xdigit:] です。例えば、 [[:alnum:]]は [0-9A-Za-z] と同じですが、後者は POSIX ロケールや ASCII コード順に依存 しますので、前者の方がロケールや文字集合に依存しません。 (クラス名の中の角括弧はシンボル名の一部であり、リストを区切る角括弧とは別に指定 する 必要があることに注意) リストの中では、ほとんどのメタ文字は通常の文字として扱われます。リテラル ] を含めるには、この文字をリストの先頭に置いてください。同様に、リテラル ^ を含めるには、この文字をリストの先頭以外に置いてください。リテラル - を含めるには、この文字をリストの最後に置いてください。

ピリオド . は、任意の 1 文字にマッチします。シンボル \w は [[:alnum:]]と同じ意味で、シンボル \W は [^[:alnum:]] と同じ意味です。

キャレット ^ と、ドル記号 $ は、それぞれ行頭と行末の空文字列にマッチ する メタ文字です。シンボル \< とシンボル \> は、それぞれ単語の先頭と末尾の空文字列にマッチするメタ文字です。シンボル \b は単語の端の空文字列 にマッチします。シンボル \B は単語の端 以外の空文字列にマッチします。

正規表現の後には、繰り返し演算子のどれかが続くことがあります。
? 直前の項目はオプションであり、最大 1 回マッチします。
* 直前の項目は 0 回以上マッチします。
+ 直前の項目は 1 回以上マッチします。
{n} 直前の項目は厳密に n 回マッチします。
{n,} 直前の項目は n 回以上マッチします。
{n,m} 直前の項目は、最低 n 回、最大 m 回マッチします。

2 つの正規表現は結合可能です。結果としてできあがる正規表現は、結合された 2 つの部分表現にそれぞれマッチする 2 つの部分文字列を結合した任意 の文字列にマッチします。

2 つの正規表現は中置き型演算子 | で繋ぐことが可能です。結果としてできあがる正規表現は、どちらかの部分表現にマッチする任意の文字列にマッチし ます。

繰 り返しは結合に優先します。また結合は選択に優先します。これらの優先規則を無効とするために、部分表現全体を括弧で囲むことが可能です。

n が 1 つの数字であるような後方参照 \n は、正規表現中の括弧で囲まれた n番目の部分表現がマッチした文字列とマッチします。

基 本正規表現では、メタ文字 ?, +, {, |, (, ) は、その特殊な意味を失います。代わりに、バックスラッシュを付けた \?, \+, \{, \|, \(, \) を使用 してください。

伝 統的な egrep は、メタ文字 { をサポートしませんでした。また、このメタ文字の代わりに \{ をサポートする egrep 実装もいくつか存在するので、移植可 能なスクリプトでは、リテラル { にマッチさせるために egrep パターンで{ を使うことは避けて [{] を使うべきです。

GNU egrep は、 { が不正な範囲指定の始まりであるなら特殊文字ではない、と想 定 し て、伝統的な使用法のサポートを試みます。例えば、シェルコマンドegrep ’{1’ は正規表現の文法エラーを報告せずに、2 文字の文字列 {1 を検索します。 POSIX.2 は、この動作を一つの拡張として許可していますが、移植可能なスクリプトではこの使用法を避けるべきです。

環境変数
GREP_OPTIONS
この変数は明示的なオプションの前に指定されるデフォルトオプションを指定します。例えば、もし GREP_OPTIONS が ’--binary-files=with- out-match --directories=skip’ である場合、 grep は 2 つのオプション --binary-files=without-match と --directories=skip が明示的なオプションの前に指定されている様に動作します。オプションの指定は空白によって区切られます。バックスラッシュは次の文字をエスケープします。これは空白やバックスラッシュを含むオプションを指定するために用いられます。

LC_ALL, LC_MESSAGES, LANG
これらの変数は grep がメッセージに使用する言語を決定する LC_MES-SAGES を指定します。ロケールはこれらの変数のうち最初に設定されているものにより決定されます。もしこれらの変数全てが設定されていない場合、またはメッセージカタログがインストールされていない場合、または grep が国際言語サポートつき (NLS) でコンパイルされてない場合には、アメリカンイングリッシュが用いられます。

LC_ALL, LC_CTYPE, LANG
これらの変数は、例えばどの文字が空白であるかなど、文字の種類を決定する LC_CTYPE を指定します。ロケールはこれらの変数のうち最初に設定されているものにより決定されます。もしこれらの変数全てが設定されていない場合、またはメッセージカタログがインストールされていない場合、または grep が国際言語サポートつき (NLS) でコンパイ ルされてない場合には、 POSIX ロケールが用いられます。

POSIXLY_CORRECT
設 定されている場合、 grep は POSIX.2 として動作し、それ以外の場合は grep は他の GNU プログラムのように動作します。 POSIX.2 ではファイル名の後に続くオプションはファイル名として扱われます。デフォルトでは、このようなオプションはオペランドリストの先頭に並び変えられて、オプションとして扱われます。また、POSIX.2 では認識できないオプションは “ 不法 (illegal)” であると診断されますが、法 律に 違 反 し て いるわけではないので、デフォルトではこれらは“不正 (invalid)” であると診断されます。

診断
通常、パターンにマッチした行が見つかった場合は 0 を、見つからなかった場合 は 1 を返します。(ただし、 -v オプションを指定した場合は、逆になります。) パターンに文法エラーが存在したり、入力ファイルにアクセスできな いなどのシステムエラーが発生した場合は、2 を返します。

バグ
バ グレポートは、 bug-gnu-utils@gnu.org まで Email してください。この時、“Subject:” のどこかに “grep” という単語を忘れずに入れてください。

{m,n} の表現で非常に大きな繰り返しを指定すると、非常に多くのメモリを 消費 します。さらに、ある種のあいまいな正規表現を指定すると、必要となる時間とメモリ領域は指数的に増大し、 grep がメモリ不足を起こす可能性があ ります。

後方参照は非常に動作が遅く、必要となる時間は指数的に増大します。

【 grep 】 文字列を検索する
UNIXの部屋 コマンド検索: grep
grep について分かりやすく書かれています。感謝。


   チップス