1. 程式人生 > >fgrep---指定的輸入檔案中的匹配模式的行

fgrep---指定的輸入檔案中的匹配模式的行

fgrep命令是用來搜尋 file 引數指定的輸入檔案(預設為標準輸入)中的匹配模式的行。fgrep 命令特別搜尋 Pattern 引數,它們是固定的字串。如果在 File 引數中指定一個以上的檔案 fgrep 命令將顯示包含匹配行的檔案。

fgrep 命令於 grep 和 egrep 命令不同,因為它搜尋字串而不是搜尋匹配表示式的模式。fgrep 命令使用快速的壓縮演算法。$, *, [, |, (, )\等字串被 fgrep 命令按字面意思解釋。這些字元並不解釋為正則表示式,但它們在 grep 和 egrep 命令中解釋為正則表示式。因為這些字元對於 shell 有特定的含義,完整的字串應該加上單引號‘ ... ’

。. 如果沒有指定檔案, fgrep 命令假定標準輸入。一般,找到的每行都複製到標準輸出中去。如果不止一個輸入檔案,則在找到的每行前列印檔名。

  1. fgrep 命令和帶 -F 標誌的 grep命令是一樣的但出錯和用法訊息不同-s 標誌功能也不同。
  2. 每行限制在 2048 個位元組。
  3. 段落(-p 標誌下)目前限制在5000個字元的長度。
  4. 不要在特定的檔案中執行 grep 命令,因為會產生不可預料的結果。
  5. 輸入行不能包含空字元。
  6. 輸入檔案應該以換行字元結尾。
  7. 雖然可以同時指定很多標誌,但某些標誌會覆蓋其餘的標誌。例如,如果同時指定 -l 和 -n ,只有檔名寫入到標準輸出中去。

語法

fgrep(選項)(引數)

選項

-b:在找到的每行之前新增行所在的塊編號。使用此標誌有助於按照上下文查詢磁碟塊號碼。-b 標誌不能用於標準輸入或者管道輸入。
-c:僅顯示匹配行的計數。
-e 模式:指定模式。這個工作模式很簡單,但當此模式以 a-(減號) 開頭時卻是很有用的。
-f StringFile:指定包含字串的檔案。
-h:當多個檔案被處理時隱藏檔名。
-i:當進行比較時忽略字母的大小寫。
-l:只列出包含匹配行的檔名(一次)。檔名之間用換行符分隔。
n:將檔案中每行的相對行號置於行前。
-pSeparator:顯示包含匹配行的整個段落。段落之間將按照Separator引數指定的段落分隔符加以分隔,這些分隔符是與搜尋模式有著相同格式的模式。包含段落分隔符的行將僅用作分隔符;它們不會被包含在輸出中。預設的段落分隔符是空白行。
-q:禁止所有寫入到標準輸出的操作,不管是否為匹配行。如果選中輸入行,以 0 狀態退出。
-s:僅顯示出錯訊息。這在檢查狀態時很有用。
-v:顯示除了匹配特定模式的行以外的所有行。
-
w
:執行單詞搜尋。 -x:顯示匹配模式的行,要求無額外的字元。 -y:當進行比較時忽略字元的大小寫。

此命令返回以下出口值:

0    找到匹配項。
1    未找到匹配項。
>1   發現語法錯誤,或者檔案不可訪問(即使找到了匹配項)。

例項

搜尋幾個檔案中的一個簡單字串:

fgrep strcpy *.c

在當前目錄下所有以 .c 字串結尾的檔案中搜索字串 strcpy。

計數匹配某模式的行數:

fgrep -c 『{』pgm.cfgrep -c 『}』pgm.c

顯示在 pgm.c 中包含左括號和右括號的行的數目。

如果在您的 C 程式中一行中沒有包含多於一個 { (左括號) 或者 } (右括號),並且括號正確匹配,那麼這兩個數字將是一樣的。如果這兩個數字不一樣,您可以將包含括號的行按照他們在檔案中的位置順序顯示出來,使用以下命令:

egrep {\|} pgm.c

顯示包含某模式的檔名:

fgrep -l strcpy *.c

搜尋當前目錄下以 .c 結尾的檔案,然後顯示包含 strcpy 字串的檔名。