1.作用
Linux系統中grep命令是一種強大的文本搜索工具,它能使用正則表達式搜索文本,並把匹 配的行打印出來。grep全稱是Global Regular Expression Print,表示全局正則表達式版本,它的使用權限是所有用戶。
2.格式
grep [options]
3.主要參數
[options]主要參數:
-c:只輸出匹配行的計數。
-I:不區分大 小寫(只適用於單字符)。
-h:查詢多文件時不顯示文件名。
-l:查詢多文件時只輸出包含匹配字符的文件名。
-n:顯示匹配行及 行號。
-s:不顯示不存在或無匹配文本的錯誤信息。
-v:顯示不包含匹配文本的所有行。
pattern正則表達式主要參數:
\: 忽略正則表達式中特殊字符的原有含義。
^:匹配正則表達式的開始行。
$: 匹配正則表達式的結束行。
\<:從匹配正則表達 式的行開始。
>:到匹配正則表達式的行結束。
[ ]:單個字符,如[A]即A符合要求 。
[ - ]:范圍,如[A-Z],即A、B、C一直到Z都符合要求 。
。:所有的單個字符。
* :有字符,長度可以為0。
4.grep命令使用簡單實例
grep‘test′d∗顯示所有以d開頭的文件中包含test的行。 grep ‘test’ d*
顯示所有以d開頭的文件中包含 test的行。
grep ‘test’ aa bb cc
顯示在aa,bb,cc文件中匹配test的行。
grep‘[a−z]5′aa顯示所有包含每個字符串至少有5個連續小寫字符的字符串的行。 grep ‘[a-z]{5}’ aa
顯示所有包含每個字符串至少有5個連續小寫字符的字符串的行。
grep ‘w(es)t.*\1′ aa
如果west被匹配,則es就被存儲到內存中,並標記為1,然後搜索任意個字符(.),這些字符後面緊跟著 另外一個es(\1),找到就顯示該行。如果用egrep或grep -E,就不用”\”號進行轉義,直接寫成’w(es)t.\1′就可以了。
5.grep命令使用復雜實例
假設您正在’/usr/src/Linux/Doc’目錄下搜索帶字符 串’magic’的文件:
grepmagic/usr/src/Linux/Doc/∗sysrq.txt:∗HowdoIenablethemagicSysRQkey?sysrq.txt:∗HowdoIusethemagicSysRQkey?其中文件′sysrp.txt′包含該字符串,討論的是SysRQ的功能。默認情況下,′grep′只搜索當前目錄。如果此目錄下有許多子目錄,′grep′會以如下形式列出:grep:sound:Isadirectory這可能會使′grep′的輸出難於閱讀。這裡有兩種解決的辦法:明確要求搜索子目錄:grep−r或忽略子目錄:grep−dskip如果有很多輸出時,您可以通過管道將其轉到′less′上閱讀: grep magic /usr/src/Linux/Doc/*
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 -n pattern files 即可顯示行號信息
grep -c pattern files 即可查找總行數
這裡還有些用於搜索的特殊符號:
\< 和 > 分別標注單詞的開始與結尾。
例如:
grep man * 會匹配 ‘Batman’、’manic’、’man’等,
grep ‘\
b034325
a081016
m7187998
m7282064
a022021
a061048
m9324822
b103303
a013386
b044525
m8987131
B081016
M45678
B103303
BADc2345
a081016
a022021
a061048
b103303
a013386
b044525
a081016
m7187998
m7282064
a022021
a061048
m9324822
b103303
a013386
b044525
m8987131
B081016
M45678
B103303
BADc2345
b103303
b044525
b103303
b044525
B081016
B103303
BADc2345
sys::3:root,bin,sys,adm
adm::4:root,adm,daemon
uucp::5:root,uucp
mail::6:root
tty::7:root,tty,adm
lp::8:root,lp,adm
nuucp::9:root,nuucp
daemon::12:root,daemon
nuucp::9:root,nuucp
B103303
m7187998
m7282064
a022021
a061048
m9324822
a013386
b044525
m8987131
B081016
M45678
BADc2345
15:B103303
echo "$path\t$res\t$fstype\t$opts\t$desc"
>>/tmp/sharetab.
[ "x$fstype" != xnfs ] &&
echo "$path\t$res\t$fstype\t$opts\t$desc"
>>/tmp/sharetab.
/usr/bin/touch -r /etc/dfs/sharetab /tmp/sharetab./usr/bin/mv−f/tmp/sharetab.
/usr/bin/mv -f /tmp/sharetab. /etc/dfs/sharetab
if [ -f /etc/dfs/dfstab ] && /usr/bin/egrep -v ‘^[ ]*(#|)′if[)’
if [ startnfsd -eq 0 -a -f /etc/rmmount.conf ] &&
if [ startnfsd−ne0];thenelif[!−n“startnfsd -ne 0 ]; then
elif [ ! -n “_INIT_RUN_LEVEL” ]; then
while [ $wtime -gt 0 ]; do
wtime=
expr $wtime - 1if [ wtime−eq0];thenecho“Usage:wtime -eq 0 ]; then
echo “Usage: 0 { start | stop }”
The end
==================================================================
1,簡介
使用正則表達式的一個多用途文本搜索工具.這個php?name=%C3%FC%C1%EE” onclick=”tagshow(event)” class=”t_tag”>命令本來是ed行編輯器中的一個php?name=%C3%FC%C1%EE” onclick=”tagshow(event)” class=”t_tag”>命令/過濾器:
g/re/p – global - regular expression - print.
基本格式
grep pattern [file…]
(1)grep 搜索字符串 [filename]
(2)grep 正則表達式 [filename]
在文件中搜索所有 pattern 出現的位置, pattern 既可以是要搜索的字符串,也可以是一個正則表達式.
注意:在輸入要搜索的字符串時最好使用雙引號/而在模式匹配使用正則表達式時,注意使用單引號
2,grep的選項
-c 只輸出匹配行的計數
-i 不區分大小寫(用於單字符)
-n 顯示匹配的行號
-v 不顯示不包含匹配文本的所以有行
-s 不顯示錯誤信息
-E 使用擴展正則表達式
更多的選項請查看:man grep
3,常用grep實例
(1)多個文件查詢
grep “sort” *.doc #見文件名的匹配
(2)行匹配:輸出匹配行的計數
grep -c “48” data.doc #輸出文檔中含有48字符的行數
(3)顯示匹配行和行數
grep -n “48” data.doc #顯示所有匹配48的行和行號
(4)顯示非匹配的行
grep -vn “48” data.doc #輸出所有不包含48的行
(4)顯示非匹配的行
grep -vn “48” data.doc #輸出所有不包含48的行
(5)大小寫敏感
grep -i “ab” data.doc #輸出所有含有ab或Ab的字符串的行
4, 正則表達式的應用
(1)正則表達式的應用 (注意:最好把正則表達式用單引號括起來)
grep ‘[239].’ data.doc #輸出所有含有以2,3或9開頭的,並且是兩個數字的行
(2)不匹配測試
grep ‘^[^48]’ data.doc #不匹配行首是48的行
(3)使用擴展模式匹配
grep -E ‘219|216’ data.doc
(4) …
這需要在實踐中不斷應用和總結,熟練掌握正則表達式。
5, 使用類名
可以使用國際模式匹配的類名:
[[:upper:]] [A-Z]
[[:lower:]] [a-z]
[[:digit:]] [0-9]
[[:alnum:]] [0-9a-zA-Z]
[[:space:]] 空格或tab
[[:alpha:]] [a-zA-Z]
(1)使用
grep ‘5[[:upper:]][[:upper:]]’ data.doc #查詢以5開頭以兩個大寫字母結尾的行