這篇文章主要講解了“Linux grep的高級使用”,文中的講解內(nèi)容簡單清晰,易于學習與理解,下面請大家跟著小編的思路慢慢深入,一起來研究和學習“Linux grep的高級使用”吧!
成都創(chuàng)新互聯(lián)公司專注于定西企業(yè)網(wǎng)站建設,響應式網(wǎng)站,商城網(wǎng)站建設。定西網(wǎng)站建設公司,為定西等地區(qū)提供建站服務。全流程按需規(guī)劃網(wǎng)站,專業(yè)設計,全程項目跟蹤,成都創(chuàng)新互聯(lián)公司專業(yè)和態(tài)度為您提供的服務
所需的文件
wget http://linux.vbird.org/linux_basic/0330regularex/regular_express.txt
搜尋特定字符
搜尋特定字串很簡單吧?假設我們要從剛剛的文件當中取得 the 這個特定字串,最簡單的方 式就是這樣:
grep -n 'the' filename
加 -n會顯示文件行號,而且還是區(qū)分大小寫的
不區(qū)分大小寫的查找,會發(fā)現(xiàn)比上邊多了幾行,那是因為不區(qū)分大小寫,把所有的行顯示出來
利用中括號[]來搜尋字符
如果我想要搜尋 test 或 taste 這兩個單字時,可以發(fā)現(xiàn)到,其實它們有共通的 't?st' 存在~這 個時候,我可以這樣來搜尋
grep -n 't[ea]st' filename
其實 [] 里面不論有幾個字符,他都僅代表某“一個”字符, 所以,上面的例子說明 了,我需要的字串是“tast”或“test”兩個字串而已! 而如果想要搜尋到有 oo 的字符時,則使 用:
但是,如果我不想要 oo 前面有 g 的話呢?此時,可以利用在集合字符的反向選擇 來達成 意思就是說,我需要的是 oo ,但是 oo 前面不能是 g 就是了!仔細比較上面兩個表格,你會 發(fā)現(xiàn),第 1,9 行不見了,因為 oo 前面出現(xiàn)了 g 所致!第 2,3 行沒有疑問,因為 foo 與 Foo 均 可被接受!但是第 18 行明明有 google 的 goo 啊~別忘記了,因為該行后面出現(xiàn)了 tool 的 too ?。∷栽撔幸脖涣谐鰜怼?也就是說, 18 行里面雖然出現(xiàn)了我們所不要的項目 (goo) 但是由于有需要的項目 (too) , 因此,是符合字串搜尋的喔!至于第 19 行,同樣的,因為 goooooogle 里面的 oo 前面可能是 o ,例如: go(ooo)oogle ,所以,這一行也是符合需求的
取出oo前邊的小寫
取出帶數(shù)字的行
取出以the開頭的行
取出以小寫字母開頭的行
取出開頭不想為字母的行
取出尾行為小數(shù)點的
小數(shù)點具有其他意義,所以必須要使用跳脫字符(\)來加 以解除其特殊意義!
取出空白行
需要找出 g??d 的字串
想要找出 g 開頭與 g 結(jié)尾的字串
但測試的結(jié)果竟然出現(xiàn)這么多行?太詭異了吧?其實一點也不詭異,因為 gg 里面的 g 代 表“空字符或一個以上的 g” 在加上后面的 g ,因此,整個 RE 的內(nèi)容就是 g, gg, ggg, gggg , 因此,只要該行當中擁有一個以上的 g 就符合所需了!
那該如何得到我們的 g....g 的需求呢?呵呵!就利用任意一個字符“.”??! 亦即是:“g.g”的作 法,因為 可以是 0 或多個重復前面的字符,而 . 是任意字符,所以: “.* 就代表零個或多個任 意字符”的意思啦!
13. 要找出“任意數(shù)字”的行列
14.
當我們搜尋配置文件時,那是相當痛苦的,因為配置文件里邊有很多都是#開頭的,但是我們又不需要的,下來就解決這個問題
搜尋出不以#開頭的
當文件里邊有空格時,去除空格的也是可以的
感謝各位的閱讀,以上就是“Linux grep的高級使用”的內(nèi)容了,經(jīng)過本文的學習后,相信大家對Linux grep的高級使用這一問題有了更深刻的體會,具體使用情況還需要大家實踐驗證。這里是創(chuàng)新互聯(lián),小編將為大家推送更多相關知識點的文章,歡迎關注!