kazmax - Linux で自宅サーバー

grep - コマンド (プログラム) の説明 - Linux コマンド集 一覧表

  1. 名称
  2. 書式
  3. 解説
  4. オプション
  5. 正規表現
  6. 環境変数
  7. 診断
  8. バグ

名称

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

書式

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

解説

grep は、 FILE で名前を指定された入力ファイル (ファイルが指定されてないか、 file の部分に - が指定された場合は標準入力) を読み込み、与えられた PATTERN にマッチする部分を含む行を探します。 デフォルト動作では、 grep はマッチした行を表示します。

さらに、2 つのプログラム egrepfgrep を利用可能です。 egrepgrep-E と同じです。 fgrepgrep-F と同じです。 zgrepgrep-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 であると仮定します。 デフォルトでは TYPEbinary であり、 grep は通常、バイナリファイルの一致を示す一行メッセージを表示するか、 マッチしない場合にはなにも表示しません。 TYPEwithout-match の場合、 grep はバイナリファイルはマッチしないものと仮定します。 これは -I オプションと等価です。 TYPEtext の場合、 grep はバイナリファイルをテキストであるかのように扱います。 これは -a オプションと等価です。 警告: "grep --binary-files=text" はバイナリのゴミを表示する可能性があります。 出力先が端末である場合で、 端末ドライバがこのゴミの一部をコマンドであると解釈する場合、 このゴミが悪い副作用をおよぼす可能性があります。
-c , --count
通常の出力はせず、各入力ファイルについてマッチした行数を表示します。 -v , --invert-match オプションと共に指定した場合は、 マッチしなかった行数を表示します (下記参照)。
-d ACTION , --directories= ACTION
入力ファイルがディレクトリの場合に、 ACTION を使ってその処理を行います。デフォルトでは ACTIONread であり、ディレクトリを普通のファイルであるかの様に読み取る事を意味します。 ACTIONskip なら、ディレクトリを黙って読み飛ばします。 ACTIONrecurse なら、 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
指定されたファイルが存在しないことや読み込みできないことを示す エラーメッセージを抑止します。 移植性に関する注: -1GNU0 grep とは異なり、 伝統的な grep は -1POSIX.20 に適合していませんでした。なぜなら、伝統的な grep には -q オプションが無く、 -s オプションは -1GNU0 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 (-1ASCII0 NUL 文字) を出力します。 例えば、 "grep -l --null" は各ファイル名の後に、通常の newline ではなくバイト 0 を出力します。 このオプションを指定すると、 newline 等の例外的な文字を含むファイル名に直面した場合でも 出力が明白になります。 このオプションを find -print0 , perl -0 , sort -z , "xargs -0" 等のコマンドと共に使用すれば、任意のファイル名を処理できます。 ファイル名が newline 文字を含んでいても処理可能です。
-Z , --decompress
検索を開始する前に入力データを伸長します。 このオプションは zlib ライブラリと共にコンパイルした場合のみ使用可能です。

正規表現

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

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

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

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

ピリオド . は、任意の 1 文字にマッチします。 シンボル \w と同じ意味で、 シンボル \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 パターンで { を使うことは避けて [{] を使うべきです。

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

環境変数

GREP_OPTIONS
この変数は明示的なオプションの前に指定されるデフォルトオプションを 指定します。例えば、もし GREP_OPTIONS'--binary-files=without-match --directories=skip' である場合、 grep は 2 つのオプション --binary-files=without-match--directories=skip が明示的なオプションの前に指定されている様に動作します。 オプションの指定は空白によって区切られます。 バックスラッシュは次の文字をエスケープします。 これは空白やバックスラッシュを含むオプションを指定するために用いられます。
LC_ALL , LC_MESSAGES , LANG
これらの変数は grep がメッセージに使用する言語を決定する LC_MESSAGES を指定します。 ロケールはこれらの変数のうち最初に設定されているものにより決定されます。 もしこれらの変数全てが設定されていない場合、またはメッセージカタログが インストールされていない場合、または grep が国際言語サポートつき (-1NLS0) でコンパイルされてない場合には、 アメリカンイングリッシュが 用いられます。
LC_ALL , LC_CTYPE , LANG
これらの変数は、 例えばどの文字が空白であるかなど、文字の種類を決定する LC_CTYPE を指定します。 ロケールはこれらの変数のうち最初に設定されているものにより決定されます。 もしこれらの変数全てが設定されていない場合、またはメッセージカタログが インストールされていない場合、または grep が国際言語サポートつき (-1NLS0) でコンパイルされてない場合には、 -1POSIX0 ロケールが用いられます。
POSIXLY_CORRECT
設定されている場合、 grep は -1POSIX.20 として動作し、それ以外の場合は grep は他の -1GNU0 プログラムのように動作します。 -1POSIX.20 ではファイル名の後に続くオプションは ファイル名として扱われます。 デフォルトでは、このようなオプションはオペランドリストの先頭に 並び変えられて、オプションとして扱われます。 また、-1POSIX.20 では認識できないオプションは (lq 不法 (illegal)(rq であると診断されますが、 法律に違反しているわけではないので、 デフォルトではこれらは(lq不正 (invalid)(rq であると診断されます。

診断

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

バグ

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

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

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