linuxgrepor
A. linux下Grep命令的詳細使用方法
在linux中grep命令是非常有用的,它和管道(|)配合使用,非常強大,用於搜索文本文件.如果想要在幾個文本文件中查找一字元串,可以使用『grep』命令。『grep』在文本中搜索指定的字元串。
假設您正在『/usr/src/linux/Documentation』目錄下搜索帶字元串『magic』的文件:
$ grep magic /usr/src/linux/Documentation/*
sysrq.txt:* How do I enable the magic SysRQ key?
sysrq.txt:* How do I use the magic SysRQ key?
其中文件『sysrp.txt』包含該字元串,討論的是 SysRQ 的功能。
默認情況下,『grep』只搜索當前目錄。如果此目錄下有許多子目錄,『grep』會以如下形式列出:
grep: sound: Is a directory
這可能會使『grep』的輸出難於閱讀。這里有兩種解決的辦法:
明確要求搜索子目錄:grep -r
或忽略子目錄:grep -d skip
當然,如果預料到有許多輸出,您可以通過 管道 將其轉到『less』上閱讀:
$ grep magic /usr/指汪src/linux/Documentation/* | less
這樣,您就可以更方便地閱讀。
有一點要注意,您必需提供一個文件過濾方式(搜索全部文件的話用 *)。如果您忘了,『grep』會一直等著,直到該程序被中斷。如果您遇到了這樣的情況,按
下面是一些有意思的命令行參數:
grep -i pattern files :不區分大小寫地搜索。默認情況區分大小寫,
grep -l pattern files :只列出匹配的文件名,
grep -L pattern files :列出不匹配的文件名,
grep -w pattern files :只匹配整個單詞,而不是字元串的一部分(如匹配『magic』,而不是『magical』),
grep -C number pattern files :匹配的上下文分別顯示[number]行,
grep pattern1 | pattern2 files :顯示匹配 pattern1 或 pattern2 的行,
grep pattern1 files | grep pattern2 :顯示既匹配 pattern1 又匹配 pattern2 的行。
這里還有些用於搜索的特殊符號:
\< 和 \> 分別標注單詞的開始與結尾。
例如:
grep man * 會匹配 『Batman』、『manic』、『man』等,
grep '\
'^':指匹配的字元串在行首,
'$':指匹配的字元串在行尾,
如果您不習慣命令行參數,可以試試圖形界雹逗伏面的『grep』,如 reXgrep 。這個軟體提供 AND、OR、NOT 等語法,還有漂亮的按鈕 :-) 。如果您只是需要更清楚的輸出,不妨試試 fungrep 。
B. Linux下Grep命令的詳細使用方法
在Linux中,grep命令是一個非常有用的工具,它與管道(|)結合使用,功能強大,主要用於搜索文本文件中的特定字元串。假如你需要在一個目錄下的多個文件中查找含有特定字元串的內容,可以使用grep命令。例如,在/usr/src/linux/Documentation目錄下查找包含「magic」字元串的文件,命令如下:
$ grep magic /usr/src/linux/Documentation/*
輸出結果可能會顯示類似這樣的內容:
sysrq.txt:* How do I enable the magic SysRQ key?
sysrq.txt:* How do I use the magic SysRQ key?
其中,sysrq.txt文件包含了該字元串,討論的是SysRQ的功能。默認情況下,grep命令僅搜索當前目錄。如果目錄下有很多子目錄,grep會以如下形式列出:
grep: sound: Is a directory
這會使grep的輸出難以閱讀。這里有兩種解決辦法:
明確要求搜索子目錄:grep -r
忽略子目錄:grep -d skip
當然,如果預料到有很多輸出,可以通過管道將其轉到less上閱讀:
$ grep magic /usr/src/linux/Documentation/* | less
這樣,就可以更方便地閱讀輸出內容。需要注意的是,你必須提供一個文件過濾方式(搜索全部文件時使用*)。如果你忘記提供,grep會一直等待,直到該程序被中斷。如果你遇到這種情況,可以按Ctrl+C中斷,然後再試。
以下是一些有意思的命令行參數:
- grep -i pattern files:不區分大小寫地搜索,默認情況下區分大小寫。
- grep -l pattern files:只列出匹配的文件名。
- grep -L pattern files:列出不匹配的文件名。
- grep -w pattern files:只匹配整個單詞,而不是字元串的一部分(如匹配「magic」,而不是「magical」)。
- grep -C number pattern files:匹配的上下文分別顯示[number]行。
- grep pattern1 | pattern2 files:顯示匹配pattern1或pattern2的行。
- grep pattern1 files | grep pattern2:顯示既匹配pattern1又匹配pattern2的行。
這里還有一些用於搜索的特殊符號:
- < 和 > 分別標注單詞的開始與結尾。例如:grep man * 會匹配 『Batman』、『manic』、『man』等,而grep <man> 只匹配『man』,而不是『Batman』或『manic』等其他的字元串。
- ^:指匹配的字元串在行首。
- $:指匹配的字元串在行尾。
如果你不習慣命令行參數,可以嘗試使用圖形界面的grep,如reXgrep。這個軟體提供了AND、OR、NOT等語法,還有漂亮的按鈕。如果你想獲得更清晰的輸出,不妨試試fungrep。