《LINUX實操:Linux文本處理三劍客之grep&正則表達式》要點:
本文介紹了LINUX實操:Linux文本處理三劍客之grep&正則表達式,希望對您有用。如果有疑問,可以聯系我們。
grep是一個文本過濾工具,它支持正則表達式,能把搜索匹配到的行打印出來.grep的全稱是Global Regular Expression Print(全局正則表達式)使用權限是所有用戶.
作用:依照用戶指定的模式對目標進行搜索后輸出
模式:正則表達式與文本字符
依照指定的字符搜索
#單引號只是字符串,雙引號識別變量、反單引號識別變量識別命令
grep "$USER" /etc/passwd
grep '$USER' /etc/passwd
grep`whoami` /etc/passwd
各項參數
--color=auto: 對匹配到的文本著色顯示
-v: 顯示不被pattern匹配到的行
-i: 忽略字符大小寫
-n:顯示匹配的行號
-c: 統計匹配的行數
-o: 僅顯示匹配到的字符串
-q: 靜默模式,不輸出任何信息
-A #: after, 后#行
-B #: before, 前#行
-C #:context, 前后各#行
-e:實現多個選項間的邏輯or關系
-w:匹配整個單詞
-E:使用ERE
-F:相當于fgrep,不支持正則表達式
-e:或
grep -e 'root' -e 'admin' file
由一類特殊字符及文本字符所編寫的模式,其中的某些字符不是字面意義,而是用來表示其規定范圍內的內容.
grep
擴展正則表達式 ERE-----egrep
或者grep -E
基本與擴展正則表達式區別在于兩者元字符不同
元字符:一個字符出現以后,它并不表示文件本身,
而是用來匹配一定范圍內的或者指定符合條件的字符;
元字符分為 字符匹配、次數匹配、位置錨定、分組
. 匹配任意單個字符
[] 匹配任意范圍內的任意單個字符
[^] 匹配指定范圍外的任意單個字符
[:alnum:] 字母和數字
[:alpha:] 匹配大小寫字母
[:lower:] 小寫字母
[:upper:] 大寫字母
[:blank:] 空白字符,包括空格與制表符
[:space:] 水平和垂直的空白字符(比[:blank:]包括的范圍廣)
[:cntrl:] 不可打印的控制字符(退格、刪除、警鈴...)
[:digit:] 十進制數字 [:xdigit:]十六進制數字
[:graph:] 可打印的非空白字符
[:print:] 可打印字符
[:punct:] 標點符號
* 匹配前字符任意次數,包括0次;貪婪模式,盡可能長的匹配
.* 任意長度任意字符.(點為任意單個,*為任意次)
\? 前一字符0次或者1次
\+ 前一字符至少1次
\{n\} 前一字符n次
\{m,n\} 前一字符m到n次
\{,n\} 前一字符最多n次
\{m,\} 前字符最少m次
^ 行首錨定
$ 行尾
^abc$ 用于匹配正行只有abc字符
^$ 匹配空行
^[[:space:]]*$ 空白行
\< 詞首錨定
\> 詞首錨定
\<abc\> 匹配整個單詞
\(\) 將多個字符捆綁在一起,當做一個整體
\1 \2 捆綁在一起的整體成為組,用 \1 \2 表示表示第一組第二組
從左起第一個括號,到與其匹配的括號為止為1組
舉例
\(string1\+\(string2\)*\)
\1 為string1\+\(string2\)*
\2 為string2
#
分組的引用
#當通過\1再次引用字符串是,\1表示之前()組內匹配的結果.
或者
a\|b: a或者b
\(C\|c\)at: Cat或者cat
proc/meminfo文件中以大小s開頭的行(要求:使用兩種辦法)
[root@CentOS7 app]# grep ^[S\|s] /proc/meminfo
SwapCached: 0 kB
SwapTotal: 2097148 kB
SwapFree: 2097148 kB
Shmem: 7868 kB
Slab: 110820 kB
SReclaimable: 54148 kB
SUnreclaim: 56672 kB
顯示/etc/passwd文件中不以/bin/bash結尾的行
[root@centos7 app]# grep -v "/bin/bash$" /etc/passwd
顯示用戶rpc默認的shell程序
[root@centos7 app]# grep -w ^rpc /etc/passwd|cut -d: -f7
找出/etc/passwd中的兩位或三位數
[root@centos7 app]# grep -w "[[:digit:]]\{2,3\}" /etc/passwd
[root@centos7 app]# grep -w "[0-9]\{2,3\}" /etc/passwd
顯示CentOS7的/etc/grub2.cfg文件中,至少以一個空白字符開頭的且后面存非空白字符的行
[root@centos7 app]# grep "^[[:space:]]\+[^[:space:]]" /etc/grub2.cfg
找出“netstat -tan”命令的結果中以‘LISTEN’后跟任意多個空白字符結尾的行
[root@centos7 app]# netstat -tan | grep "LISTEN[[:space:]]\+"
顯示CentOS7上所有系統用戶的用戶名和UID
[root@centos7 app]# cut -d: -f1,3 /etc/passwd|grep -w "[[:digit:]]\{1,3\}$"|sort -t: -k2
添加用戶bash、testbash、basher、sh、nologin(其shell為/sbin/nologin),找出/etc/passwd用戶名同shell名的行
[root@centos7 app]# grep -o "^\([[:alpha:]]\+\>\).*\<\1$" /etc/passwd
利用df和grep,取出磁盤各分區利用率,并從大到小排序
[root@centos7 app]# df|grep "^/dev/sd"|tr -s ' '|cut -d ' ' -f1,5|sort -t' ' -k 2 -n
[root@centos7 ~]# cut -d: -f1,3,7 /etc/passwd | grep -E -e "^root" -e "^nologin"
root:0:/bin/bash
nologin:1102:/sbin/nologin
[root@centos7 ~]# egrep "^(_|[[:alpha:]])+\(" /etc/rc.d/init.d/functions
[root@centos7 ~]# echo /etc/rc.d/init.d/functions |grep -E "[^/]+/?$" -o
[root@centos7 ~]# echo /etc/rc.d/init.d/functions |grep -E "^/.*/\<"
[root@centos7 ~]# last|tr -s ' '| cut -d ' ' -f1,3| grep "\([[:digit:]]\+.\)\{3\}[[:digit:]]\+"|sort -r|uniq -c
[root@centos7 ~]# echo {1..100}| egrep -w [0-9]{1} -o
[root@centos7 ~]# echo {1..100}| egrep -w [1-9][0-9]
[root@centos7 ~]# echo {190..300}| egrep -w 2[0-4][0-9]
[root@centos7 ~]# echo {190..300}| egrep -w 25[0-5]
[root@centos7 ~]# ifconfig | egrep "([[:digit:]]+\.){3}[[:digit:]]+" -o
[root@centos7 ~]# echo welcome to aubin linux|grep [[:alpha:]] -o|sort -n|uniq -c
本文永久更新鏈接地址:
歡迎參與《LINUX實操:Linux文本處理三劍客之grep&正則表達式》討論,分享您的想法,維易PHP學院為您提供專業教程。
轉載請注明本頁網址:
http://www.snjht.com/jiaocheng/9322.html