Linux中g(shù)rep與正則表達(dá)式的示例分析-創(chuàng)新互聯(lián)

小編給大家分享一下Linux中g(shù)rep與正則表達(dá)式的示例分析,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!

站在用戶的角度思考問(wèn)題,與客戶深入溝通,找到福鼎網(wǎng)站設(shè)計(jì)與福鼎網(wǎng)站推廣的解決方案,憑借多年的經(jīng)驗(yàn),讓設(shè)計(jì)與互聯(lián)網(wǎng)技術(shù)結(jié)合,創(chuàng)造個(gè)性化、用戶體驗(yàn)好的作品,建站類(lèi)型包括:成都網(wǎng)站制作、做網(wǎng)站、企業(yè)官網(wǎng)、英文網(wǎng)站、手機(jī)端網(wǎng)站、網(wǎng)站推廣、國(guó)際域名空間、虛擬主機(jī)、企業(yè)郵箱。業(yè)務(wù)覆蓋福鼎地區(qū)。

grep簡(jiǎ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使用方式

使用方式:

grep [OPTIONS] PATTERN [FILE...]
grep [OPTIONS] [-e PATTERN | -f FILE] [FILE...]

常用選項(xiàng):


--color=auto:對(duì)匹配到的文本著色后進(jìn)行高亮顯示;

-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ò)。

擴(kuò)展grep使用方式

使用方式:

egrep [OPTIONS] PATTERN [FILE...]
grep -E [OPTIONS] PATTERN [FILE...]

-i:忽略字符的大小寫(xiě)
-o:僅顯示匹配到的字符串本身
-v:顯示不被模式匹配到的行
-q:靜默模式,即不輸出任何信息
-A #:顯示被模式匹配的行及其后#行
-B #:顯示被模式匹配的行及其前#行
-C #:顯示被模式匹配的行及其前后各#行
-G:支持基本正則表達(dá)式

grep正則表達(dá)式元字符

‘^‘: 錨定行首

‘$': 錨定行尾

‘.‘: 匹配任一一個(gè)字符

‘*': 匹配零個(gè)或多個(gè)先前字符

‘\?‘:匹配其前面的字符0次或者1次;

‘\+':匹配其前面的字符1次或者多次;

‘\{m\}‘:匹配其前面的字符m次(\為轉(zhuǎn)義字符)

‘\{m,n\}':匹配其前面的字符至少m次,至多n次

‘[]‘: 匹配一個(gè)指定范圍內(nèi)的字符 | ‘[^]'匹配指定范圍外的任意單個(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')

練習(xí)題:

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最多的那個(gè)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

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

以上是“Linux中g(shù)rep與正則表達(dá)式的示例分析”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內(nèi)容對(duì)大家有所幫助,如果還想學(xué)習(xí)更多知識(shí),歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道!

名稱欄目:Linux中g(shù)rep與正則表達(dá)式的示例分析-創(chuàng)新互聯(lián)
URL網(wǎng)址:http://www.muchs.cn/article44/dpjhhe.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站改版、手機(jī)網(wǎng)站建設(shè)、App設(shè)計(jì)、App開(kāi)發(fā)建站公司、電子商務(wù)

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)

手機(jī)網(wǎng)站建設(shè)