Linux中grep的使用以及grep的練習

grep:經過一個指定的模式匹配指定的行nginx

         經常使用選項:git

                   --color=auto:對匹配到的串作高亮顯示;正則表達式

                   -v:顯示模式匹配不到行;shell

                   -i:忽略字符大小寫;centos

                   -o:僅顯示可以被模式匹配到的串本行;bash

                   -q:靜默模式;ide

                   -E:使用擴展的正則表達式;spa

                   -o:  只獲取匹配到的內容;3d

                   -Anum :  匹配到搜索到的行以及該行下面的num;blog

                   -Bnum :  匹配到搜索到的行以及該行上面的num;

                   -Cnum : 匹配到搜索到的行以及上下各num;

                   -n: 顯示文件的行數;

                   -r  : 遞歸目錄搜索指定內容的文件;

                  

         基本正則表達式的元字符:

                   字符匹配:

                            .:匹配任意單個字符;

                            []:匹配指定範圍內的任意單個字符;

                            [^]:匹配指定範圍內的任意單個字符;

                            [:lower:]匹配小寫字母

                            [:upper:]匹配大寫字母

                            [:alpha]匹配全部字母

                            [:digit:]匹配全部數字

                            [:alnum:]匹配全部數字字母 [:alpha:][:alpha:]和二爲一

                            [:space]表明空格字符 例如:tab,換行,空格之類的

                            [:punct:]表明標點符號 例如:'! "# $ % & ' ( ) * + , - . / : ; < = > ? @ [ ] ^ _ ' { | }

                   次數匹配:用於要指定其次數的字符的後面;

                            *:任意次;

                            \?01次;

                            \+1或屢次;

                            \{m\}:精確限制爲m次;

                            \{m,n\}:至少m次,至多n次,[m,n];

                            \{0,n\}:至多n次;

                            \{m,\}:至少m次;

                            .*:匹配任意長度的任意字符;

                   位置錨定:

                            ^:行首錨定;用於模式的最左側;

                            $:行尾錨定;用於模式的最右側;

                            \<,\b: 詞首錨定;用於表示單詞的模式的左側;

                            \>,\b:詞尾錨定;用於表示單詞的模式的右側;

                            ^$:空白行;

                            分組:\(\)

                            分組的小括號中的模式匹配到的內容,會在執行過程當中被正則表達式引擎記錄下來,並保存內置的變量中;這些變量分別是\1, \2, ...

                            \1:從左側起,第一個左括號,以及與之配對的右括號中間的模式所匹配到的內容;

                            後向引用:使用變量引用前面的分組括號中的模式所匹配到的字符;

                  

                  

         擴展正則表達式的元字符:

                   字符匹配:

                            .:匹配任意單個字符;

                            []:匹配指定範圍內的任意單個字符;

                            [^]:匹配指定範圍內的任意單個字符;

                            [:lower:]匹配小寫字母

                            [:upper:]匹配大寫字母

                            [:alpha]匹配全部字母

                            [:digit:]匹配全部數字

                            [:alnum:]匹配全部數字字母 [:alpha:][:alpha:]和二爲一

                            [:space]表明空格字符 例如:tab,換行,空格之類的

                            [:punct:]表明標點符號 例如:'! "# $ % & ' ( ) * + , - . / : ; < = > ? @ [ ] ^ _ ' { | }

                   次數匹配:

                            *:0次或屢次

                            ?:0次或1次;

                            +:1次以上;

                            {m}:精確匹配m次;

                            {m,n}:至少m次,至多n次;

                   錨定:

                            ^:錨定行首

                            $:錨定行尾

                            \<,\b: 詞首錨定;用於表示單詞的模式的左側;

                            \>,\b:詞尾錨定;用於表示單詞的模式的右側;

                   分組:()

                            後向引用:\1, \2,...

                   支持或的概念

                            a|b:匹配a或者b

 

                           

 練習:

1、顯示/etc/passwd文件中以bash結尾的行;

      :grep 「bash$」 /etc/passwd   

wKiom1XjFvSAQ_bOAADEjCKSFjg214.jpg


 2、顯示/etc/passwd文件中的兩位數或三位數;

       : grep "\b[[:digit:]]\{2,3\}\b" /etc/passwd

             grep -E "\b[[:digit:]]{2,3}\b"/etc/passwd                      wKiom1XjFuXB31nFAAYvrI-9J5w089.jpg

 

3、顯示'netstat -tan'命令結果中以‘LISTEN’後跟0個、1個或多個空白字符結尾的行;

      :  netstat-tan|grep 'LISTEN[[:space:]]*$'                      wKiom1XjFwPAb2JXAARRYF7k32w824.jpg


4、添加用戶bashtestbash,basher以及nologin用戶(nologin用戶的shell/sbin/nologin);然後找出/etc/passwd文件中用戶名同shell名的行;

   答:1.useraddbash

    2.useraddtestbash

     3.useradd basher

     4.useradd-s /sbin/nologin nologin

   5.grep '^\([[:alnum:]]\+\):.*\1$'  /etc/passwd           wKioL1XjGUDwZH_6AAEt0eVV05U874.jpg

 

5、顯示當前系統上rootcentosuser1用戶的默認的shellUID

       : egrep'^(root|centos|user1)' /etc/passwd|awk -F":" '{print $1,$3,$7}' wKiom1XjF66judl_AACjiu2zuxk138.jpg

 

6、找出/etc/rc.d/init.d/functions文件中某單詞(單詞中間能夠存在下劃線)後面跟着一組小括號的行;

      : egrep '^([[:alpha:]]+).+\b\(\)'/etc/rc.d/init.d/functions wKiom1XjF8jSR_dZAAIiUoaF2gQ675.jpg

 

7、使用echo輸出一個路徑,然後egrep找出其路徑基名;進一步地:使用egrep取出其目錄名;

       : 路徑基名命令:echo/usr/local/nginx/conf/nginx.conf | egrep -o '([^/]*)$'

   路徑目錄名命令:echo/usr/local/nginx/conf/nginx.conf | egrep -o '^(.*)/' wKioL1XjGfvwauDFAAE0GrmJA1g421.jpg

 

8、找出ifconfig命令執行結果中1-255之間的數字;

      : ifconfig|egrep '\b([1-9]|[1-9][1-9]|1[0-9][0-9]|2[0-5][0-5])\b'          wKioL1XjGhSgUn2pAAN2H6OZP_c317.jpg

相關文章
相關標籤/搜索