深入理解Linux中的grep命令
介紹
Linux系統(tǒng)中grep命令是一種強大的文本搜索工具,它能使用正則表達式搜索文本,并把匹 配的行打印出來。grep全稱是Global Regular Expression Print,表示全局正則表達式版本,它的使用權限是所有用戶。
grep [-acinv] [--color=auto] '查找字符串' filename
參數(shù):
-a :將binary文件以text文件的方式查找數(shù)據(jù)
-c :計算找到‘查找字符串'的次數(shù)
-i :忽略大小寫的區(qū)別,即把大小寫視為相同
-n :順便輸出行號
-v :反向選擇,即顯示出沒有‘查找字符串'內(nèi)容的那一行
-l :只顯示匹配的文件,不顯示具體內(nèi)容
-f<規(guī)則文件> : 指定規(guī)則文件,其內(nèi)容含有一個或多個規(guī)則樣式,讓grep查找符合規(guī)則條件的文件內(nèi)容,格式為每行一個規(guī)則樣式。
實例:
#取出文件/etc/man.config中包含MANPATH關鍵詞的行,并把找到的關鍵字加上顏色 grep --color=auto MANPATH /etc/man.config #把ls -l的輸出中包含字母file(不區(qū)分大小寫)的內(nèi)容輸出 ls -l | grep -i file #在文件 '/var/log/messages'中查找關鍵詞"Aug" grep Aug /var/log/messages #在文件 '/var/log/messages'中查找以"Aug"開始的行 grep ^Aug /var/log/messages #選擇 '/var/log/messages' 文件中所有包含數(shù)字的行 grep [0-9] /var/log/messages #在目錄 '/var/log' 及隨后的目錄中搜索字符串"Aug" (遞歸查找) grep Aug -R /var/log/* #在當前目錄搜索帶'energywise'行的文件 grep 'energywise' * #在當前目錄及其子目錄下搜索'energywise'行的文件 grep -r 'energywise' * #查找指定進程 ps -ef|grep svn #從文件中讀取關鍵詞進行搜索,輸出test.txt文件中含有從test2.txt文件中讀取出的關鍵詞的內(nèi)容行 cat test.txt | grep -f test2.txt
grep與正規(guī)表達式:
字符類的搜索:如果我想要搜尋 test 或 taste 這兩個單字時,可以發(fā)現(xiàn)到,其實她們有共通的 ‘t?st' 存在~這個時候,我可以這樣來搜尋:
grep -n 't[ae]st' regular_express.txt
其實 [] 里面不論有幾個字節(jié),他都謹代表某『一個』字節(jié), 所以,上面的例子說明了,我需要的字串是『tast』或『test』兩個字串而已!
字符類的反向選擇 [^] :如果想要搜索到有 oo 的行,但不想要 oo 前面有 g,如下
grep -n '[^g]oo' regular_express.txt
字符類的連續(xù):再來,假設我 oo 前面不想要有小寫字節(jié),
grep -n '[^a-z]oo' regular_express.txt
當我們在一組集合字節(jié)中,如果該字節(jié)組是連續(xù)的,例如大寫英文/小寫英文/數(shù)字等等, 就可以使用[a-z],[A-Z],[0-9]等方式來書寫,那么如果我們的要求字串是數(shù)字與英文呢? 呵呵!就將他全部寫在一起,變成:[a-zA-Z0-9]。
我們要取得有數(shù)字的那一行,就這樣:
grep -n '[0-9]' regular_express.txt
行首與行尾字節(jié) ^ $
行首字符:如果我想要讓 the 只在行首列出呢? 這個時候就得要使用定位字節(jié)了!我們可以這樣做:
grep -n '^the' regular_express.txt
開頭是小寫字節(jié)的那一行就列出呢?可以這樣:
grep -n '^[a-z]' regular_express.txt
我不想要開頭是英文字母,則可以是這樣:
grep -n '^[^a-zA-Z]' regular_express.txt
^ 符號,在字符類符號(括號[])之內(nèi)與之外是不同的! 在 [] 內(nèi)代表『反向選擇』,在 [] 之外則代表定位在行首的意義!
行尾結束為小數(shù)點 (.) 的那一行:
grep -n '\.$' regular_express.txt
特別注意到,因為小數(shù)點具有其他意義(底下會介紹),所以必須要使用轉義字符()來加以解除其特殊意義!
#找出空白行 grep -n '^$' regular_express.txt
任意一個字節(jié) . 與重復字節(jié) *
. (小數(shù)點):代表『一定有一個任意字節(jié)』的意思;
* (星號):代表『重復前一個字符, 0 到無窮多次』的意思,為組合形態(tài)
#需要找出 g??d 的字串,亦即共有四個字節(jié), 起頭是 g 而結束是 d ,我可以這樣做: grep -n 'g..d' regular_express.txt #查找至少兩個 o 以上的字串,『o*』代表的是:『擁有空字節(jié)或一個 o 以上的字節(jié)』 grep -n 'ooo*' regular_express.txt #想要字串開頭與結尾都是 g,但是兩個 g 之間僅能存在至少一個 o ,亦即是 gog, goog, gooog.... 等等 grep -n 'goo*g' regular_express.txt #找出 g 開頭與 g 結尾的行,當中的字符可有可無 grep -n 'g.*g' regular_express.txt #找到兩個 o 的字串,可以是: grep -n 'o\{2\}' regular_express.txt #找出 g 后面接 2 到 5 個 o ,然后再接一個 g 的字串,他會是這樣: grep -n 'go\{2,5\}g' regular_express.txt #2 個 o 以上的 goooo....g 呢?除了可以是 goo*g ,也可以 grep -n 'go\{2,\}g' regular_express.txt #從多個文件中查找關鍵詞 grep 'linux' test.txt test2.txt
總結
以上就是關于Linux中grep命令的全部內(nèi)容,希望本文的內(nèi)容對大家的學習或者工作能帶來一定的幫助,如果有疑問大家可以留言交流。
相關文章
shell腳本將Oracle服務器中數(shù)據(jù)定時增量刷新到ftp服務器中
這篇文章主要介紹了shell腳本將Oracle服務器中數(shù)據(jù)定時增量刷新到ftp服務器中,非常不錯,具有一定的參考借鑒價值 ,需要的朋友可以參考下2019-08-08