1. 程式人生 > >grep用法

grep用法

用法: grep [選項]... PATTERN [FILE]...
在每個 FILE 或是標準輸入中查詢 PATTERN。
預設的 PATTERN 是一個基本正則表示式(縮寫為 BRE)。
例如: grep -i 'hello world' menu.h main.c


正則表示式選擇與解釋:
  -E, --extended-regexp     PATTERN 是一個可擴充套件的正則表示式(縮寫為 ERE)
  -F, --fixed-strings       PATTERN 是一組由斷行符分隔的定長字串。
  -G, --basic-regexp        PATTERN 是一個基本正則表示式(縮寫為 BRE)
  -P, --perl-regexp         PATTERN 是一個 Perl 正則表示式
  -e, --regexp=PATTERN      用 PATTERN 來進行匹配操作
  -f, --file=FILE           從 FILE 中取得 PATTERN
  -i, --ignore-case         忽略大小寫
  -w, --word-regexp         強制 PATTERN 僅完全匹配字詞
  -x, --line-regexp         強制 PATTERN 僅完全匹配一行
  -z, --null-data           一個 0 位元組的資料行,但不是空行


雜項:
  -s, --no-messages         不顯示錯誤資訊
  -v, --invert-match        選中不匹配的行
  -V, --version             顯示版本資訊並退出
      --help                顯示此幫助並退出
      --mmap                忽略向後相容性


輸出控制:
  -m, --max-count=NUM       NUM 次匹配後停止
  -b, --byte-offset         輸出的同時列印位元組偏移
  -n, --line-number         輸出的同時列印行號
      --line-buffered       每行輸出清空
  -H, --with-filename       為每一匹配項列印檔名
  -h, --no-filename         輸出時不顯示檔名字首
      --label=LABEL         將LABEL 作為標準輸入檔名字首
  -o, --only-matching       只顯示一行中匹配PATTERN 的部分
  -q, --quiet, --silent     不顯示所有輸出
      --binary-files=TYPE   假定二進位制檔案的TYPE 型別;
                            TYPE 可以是`binary', `text', 或`without-match'
  -a, --text                等同於 --binary-files=text
  -I                        等同於 --binary-files=without-match
  -d, --directories=ACTION  操作目錄的方式;
                            ACTION 可以是`read', `recurse',或`skip'
  -D, --devices=ACTION      操作裝置、先入先出佇列、套接字的方式;
                            ACTION 可以是`read'或`skip'
  -R, -r, --recursive       等同於 --directories=recurse
      --include=FILE_PATTERN  只查詢匹配FILE_PATTERN 的檔案
      --exclude=FILE_PATTERN  跳過匹配FILE_PATTERN 的檔案和目錄
      --exclude-from=FILE   跳過所有除FILE 以外的檔案
      --exclude-dir=PATTERN  跳過所有匹配PATTERN 的目錄。
  -L, --files-without-match  只打印不匹配FILEs 的檔名
  -l, --files-with-matches  只打印匹配FILES 的檔名
  -c, --count               只打印每個FILE 中的匹配行數目
  -T, --initial-tab         行首tabs 分隔(如有必要)
  -Z, --null                在FILE 檔案最後列印空字元


檔案控制:
  -B, --before-context=NUM  列印以文字起始的NUM 行
  -A, --after-context=NUM   列印以文字結尾的NUM 行
  -C, --context=NUM         列印輸出文字NUM 行
  -NUM                      等同於 --context=NUM
      --color[=WHEN],
      --colour[=WHEN]       使用標誌高亮匹配字串;
                            WHEN 可以是`always', `never'或`auto'
  -U, --binary              不要清除行尾的CR 字元(MSDOS 模式)
  -u, --unix-byte-offsets   當CR 字元不存在,報告位元組偏移(MSDOS 模式)


‘egrep’即‘grep -E’。‘fgrep’即‘grep -F’。
直接使用‘egrep’或是‘fgrep’均已不可行了。
不帶 FILE 引數,或是 FILE 為 -,將讀取標準輸入。如果少於兩個 FILE 引數
就要預設使用 -h 引數。如果選中任意一行,那退出狀態為 0,否則為 1;
如果有錯誤產生,且未指定 -q 引數,那退出狀態為 2。