《LINUX入門:Linux之grep及正則表達(dá)式》要點(diǎn):
本文介紹了LINUX入門:Linux之grep及正則表達(dá)式,希望對(duì)您有用。如果有疑問(wèn),可以聯(lián)系我們。
grep 是一種強(qiáng)大的文本搜索工具,它能使用正則表達(dá)式搜索文本,并把匹配的行打印出來(lái).通常grep有三種版本grep、egrep(等同于grep -E)和fgrep.egrep為擴(kuò)展的grep,fgrep則為快速grep(固定的字符串來(lái)對(duì)文本進(jìn)行搜索,不支持正則表達(dá)式的引用但是查詢極為快速).grep是Linux文本處置三劍客之一.
使用方式:grep [OPTIONS] PATTERN [FILE...]
grep [OPTIONS] [-e PATTERN | -f FILE] [FILE...]
--color=auto:對(duì)匹配到的文本著色落后行高亮顯示;
-i:忽略字符的年夜小寫(xiě)
-o:僅顯示匹配到的字符串
-v:顯示不克不及被模式匹配到的行
-E:支持使用擴(kuò)大的正則表達(dá)式
-q:靜默模式,即不輸出任何信息
-A #:顯示被模式匹配的行及厥后#行
-B #:顯示被模式匹配的行及其前#行
-C #:顯示被模式匹配的行及其前后各#行
注:使用grep匹配時(shí)需使用雙引號(hào)引起來(lái)(單引號(hào)為強(qiáng)引用),防止被系統(tǒng)誤認(rèn)為參數(shù)或者特殊命令而報(bào)錯(cuò).使用方式:egrep [OPTIONS] PATTERN [FILE...]?
grep -E [OPTIONS] PATTERN [FILE...]
-i:忽略字符的大小寫(xiě)
-o:僅顯示匹配到的字符串自己
-v:顯示不被模式匹配到的行
-q:靜默模式,即不輸出任何信息
-A #:顯示被模式匹配的行及其后#行
-B #:顯示被模式匹配的行及其前#行
-C #:顯示被模式匹配的行及其前后各#行
-G:支持基本正則表達(dá)式
‘^‘: 錨定行首
‘$’: 錨定行尾?
‘.‘: 匹配任一一個(gè)字符
‘*’:?匹配零個(gè)或多個(gè)先前字符?
‘\?‘:匹配其前面的字符0次或者1次;
‘\+’:匹配其前面的字符1次或者多次;
‘\{m\}‘:匹配其前面的字符m次(\為轉(zhuǎn)義字符)
‘\{m,n\}’:匹配其前面的字符至少m次,至多n次
‘[]‘: 匹配一個(gè)指定規(guī)模內(nèi)的字符 | ‘[^]’匹配指定規(guī)模外的任意單個(gè)字符
‘\<‘或‘\b’:錨定詞首,‘\>’或‘\b’:錨定詞尾(可用\<PATTERN\>:匹配完備單詞)
‘\(\)’:將多個(gè)字符當(dāng)做一個(gè)整體進(jìn)行處置
后向引用:引用前面的分組括號(hào)中的模式所匹配到的字符
分組括號(hào)中的模式匹配到的內(nèi)容或被正則表達(dá)式引擎自動(dòng)記載于內(nèi)部的變量中:
\1:模式從左側(cè)起,第一個(gè)左括號(hào)及與之匹配的右括號(hào)之間模式匹配到的內(nèi)容
\2:模式從左側(cè)起,第二個(gè)左括號(hào)及與之匹配的右括號(hào)之間模式匹配到的內(nèi)容...
擴(kuò)展正則表達(dá)式與正則表達(dá)式略有分歧:
'[]':依舊匹配指定范圍內(nèi)的任意單個(gè)字符;然則有很多特殊匹配方式.
[:digit:] 匹配隨意率性單個(gè)數(shù)字
[:lower:] 匹配隨意率性單個(gè)小寫(xiě)字母? ? ? ? ? ? ? ?
[:upper:] 匹配任意單個(gè)年夜寫(xiě)字母
[:alpha:] 匹配隨意率性單個(gè)字母
[:alnum:] 匹配隨意率性單個(gè)字母或數(shù)字
[:punct:] 匹配隨意率性單個(gè)符號(hào)
[:space:] 匹配單個(gè)空格
一些地方撤消了轉(zhuǎn)義字符的使用:
‘?‘:匹配其前面的字符0次或者1次;
‘+’:匹配其前面的字符1次或者多次;
‘{m}‘:匹配其前面的字符m次(\為轉(zhuǎn)義字符)
‘{m,n}’:匹配其前面的字符至少m次,至多n次
():將一個(gè)或多個(gè)字符捆綁在一起,當(dāng)做一個(gè)整體進(jìn)行處置,反向引用照常使用.
‘|’:或(注:‘C|cat’為C與cat,‘(C|c)at才是Cat與cat’)
1、列出當(dāng)前系統(tǒng)上所有已經(jīng)登錄的用戶的用戶名,注意:同一個(gè)用戶登錄多次,則只顯示一次
[root@localhost ~]# who | cut -d' ' -f1|uniq root
2、取出末了登錄到當(dāng)前系統(tǒng)的用戶的相關(guān)信息
[root@localhost ~]# id `last | head -1 | cut -d' ' -f1` uid=0(root) gid=0(root) groups=0(root)
3.取出當(dāng)前系統(tǒng)上被用戶當(dāng)做其默認(rèn)shell最多的誰(shuí)人shell
[root@localhost ~]# cut -d':' -f7 /etc/passwd|uniq -c|sort -n|tail -1|cut -d' ' -f7 /sbin/nologin
4.將/etc/passd中的第三個(gè)字段設(shè)置最大的后10個(gè)用戶的信息全部改為大寫(xiě)保留至/tmp/maxuser.txt文件中
[root@localhost ~]# sort -t':' -k3 -n /etc/passwd|tail -10|tr 'a-z' 'A-Z' >/tmp/maxusers.txt [root@localhost ~]# cat /tmp/maxusers.txt NOBODY:X:99:99:NOBODY:/:/SBIN/NOLOGIN SYSTEMD-NETWORK:X:192:192:SYSTEMD NETWORK MANAGEMENT:/:/SBIN/NOLOGIN NGINX:X:996:994:NGINX WEB SERVER:/VAR/LIB/NGINX:/SBIN/NOLOGIN CHRONY:X:997:995::/VAR/LIB/CHRONY:/SBIN/NOLOGIN POLKITD:X:998:996:USER FOR POLKITD:/:/SBIN/NOLOGIN SYSTEMD-BUS-PROXY:X:999:997:SYSTEMD BUS PROXY:/:/SBIN/NOLOGIN DINGJIE:X:1000:1000:DINGJIE:/HOME/DINGJIE:/BIN/BASH JEFF:X:1001:1024:WOSHIDASHUAIBI:/HOME/JEFF:/BIN/BASH EGON:X:1002:1002::/HOME/EGON:/BIN/BASH NFSNOBODY:X:65534:65534:ANONYMOUS NFS USER:/VAR/LIB/NFS:/SBIN/NOLOGIN
5.掏出當(dāng)前主機(jī)的IP地址
[root@localhost ~]# ifconfig | egrep "inet.*broadcast.*"|cut -d' ' -f10 192.168.0.133
6.列出/etc目錄下所有已.conf結(jié)尾的文件的文件名,并將其名字轉(zhuǎn)換為大寫(xiě)后保留至/tmp/etc.conf文件中
[root@localhost ~]# find /etc -name '*.conf' | egrep -o "[^/]*(\.conf)$"|tr 'a-z' 'A-Z' >/tmp/etc.conf [root@localhost ~]# cat /tmp/etc.conf RESOLV.CONF CA-LEGACY.CONF FASTESTMIRROR.CONF LANGPACKS.CONF SYSTEMD.CONF VERSION-GROUPS.CONF LVM.CONF LVMLOCAL.CONF ASOUND.CONF LDAP.CONF MLX4.CONF RDMA.CONF SMTPD.CONF
7.顯示/var目次下一級(jí)子目次或文件的總數(shù)
[root@localhost ~]# ls /var | wc -l 21
8.掏出/etc/group第三個(gè)字段數(shù)值最小的10個(gè)組的名字
[root@localhost ~]# sort -t: -k3 -n /etc/group|head -10 |cut -d':' -f1 root bin daemon sys adm tty disk lp mem kmem
9.將/etc/fstab和/etc/issue文件的內(nèi)容合并為同一個(gè)內(nèi)容后保留至/tmp/etc.test文件中
[root@localhost ~]# cat /etc/fstab /etc/issue > /tmp/etc.test [root@localhost ~]# cat /tmp/etc.test # # /etc/fstab # Created by anaconda on Sat May 13 10:12:58 2017 # # Accessible filesystems, by reference, are maintained under '/dev/disk' # See man pages fstab(5), findfs(8), mount(8) and/or blkid(8) for more info # /dev/mapper/cl-root / xfs defaults 0 0 UUID=2789d01a-4e2b-47a5-9c3c-537641648663 /boot xfs defaults 0 0 /dev/mapper/cl-swap swap swap defaults 0 0 \S Kernel \r on an \m
對(duì)于正則表達(dá)式的使用必要多聯(lián)系加強(qiáng)記憶,否則是用不好正則表達(dá)式的,在學(xué)習(xí)過(guò)程中切記多寫(xiě)多背.
Linux敕令-文件文本操作grep?
grep正則表達(dá)式
Linux中正則表達(dá)式與文件格式化處置命令(awk/grep/sed)
Linux根基之grep和正則表達(dá)式
14 個(gè) grep 敕令的例子
Linux文本處置工具grep和正則表達(dá)式及egrep與grep區(qū)別?
Linux根基之-正則表達(dá)式(grep,sed,awk)?
Linux文本處置工具及grep? ?
grep 命令系列:如安在 UNIX 中根據(jù)文件內(nèi)容查找文件
本文永遠(yuǎn)更新鏈接地址:
學(xué)習(xí)更多LINUX教程,請(qǐng)查看站內(nèi)專欄,如果有LINUX疑問(wèn),可以加QQ交流《LINUX入門:Linux之grep及正則表達(dá)式》。
轉(zhuǎn)載請(qǐng)注明本頁(yè)網(wǎng)址:
http://www.fzlkiss.com/jiaocheng/9771.html