主頁 > 知識庫 > 淺談Linux grep與正則表達式

淺談Linux grep與正則表達式

熱門標簽:地圖標注教學點 400電話辦理電話辦理 梅縣地圖標注 外呼系統(tǒng)無呼出路由是什么原因 甘肅醫(yī)療外呼系統(tǒng)排名 西藏智能外呼系統(tǒng)代理商 貴港公司如何申請400電話 呼叫系統(tǒng)外呼只能兩次 ai電話機器人搭建

grep簡介

  grep 是一種強大的文本搜索工具,它能使用正則表達式搜索文本,并把匹配的行打印出來。通常grep有三種版本grep、egrep(等同于grep -E)和fgrep。egrep為擴展的grep,fgrep則為快速grep(固定的字符串來對文本進行搜索,不支持正則表達式的引用但是查詢極為快速)。grep是Linux文本處理三劍客之一。

grep使用方式

  使用方式:

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

  常用選項:

  --color=auto:對匹配到的文本著色后進行高亮顯示;

   -i:忽略字符的大小寫

  -o:僅顯示匹配到的字符串

  -v:顯示不能被模式匹配到的行

  -E:支持使用擴展的正則表達式

  -q:靜默模式,即不輸出任何信息

  -A #:顯示被模式匹配的行及其后#行

  -B #:顯示被模式匹配的行及其前#行

  -C #:顯示被模式匹配的行及其前后各#行

  注:使用grep匹配時需使用雙引號引起來(單引號為強引用),防止被系統(tǒng)誤認為參數(shù)或者特殊命令而報錯。

擴展grep使用方式

  使用方式:

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

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

grep正則表達式元字符

  ‘^‘: 錨定行首

  ‘$': 錨定行尾

  ‘.‘: 匹配任一一個字符

  ‘*': 匹配零個或多個先前字符

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

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

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

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

  ‘[]‘: 匹配一個指定范圍內(nèi)的字符 | ‘[^]'匹配指定范圍外的任意單個字符

  ‘\‘或‘\b':錨定詞首,‘\&;'或‘\b':錨定詞尾(可用\PATTERN\&;:匹配完整單詞)

  ‘\(\)':將多個字符當做一個整體進行處理

  后向引用:引用前面的分組括號中的模式所匹配到的字符

  分組括號中的模式匹配到的內(nèi)容或被正則表達式引擎自動記錄于內(nèi)部的變量中:

  \1:模式從左側(cè)起,第一個左括號及與之匹配的右括號之間模式匹配到的內(nèi)容

  \2:模式從左側(cè)起,第二個左括號及與之匹配的右括號之間模式匹配到的內(nèi)容...

  擴展正則表達式與正則表達式略有不同:

  '[]':依舊匹配指定范圍內(nèi)的任意單個字符;但是有很多特殊匹配方式。

    [:digit:] 匹配任意單個數(shù)字

    [:lower:] 匹配任意單個小寫字母              

    [:upper:] 匹配任意單個大寫字母

    [:alpha:] 匹配任意單個字母

    [:alnum:] 匹配任意單個字母或數(shù)字

    [:punct:] 匹配任意單個符號

    [:space:] 匹配單個空格

  一些地方取消了轉(zhuǎn)義字符的使用:

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

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

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

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

  ():將一個或多個字符捆綁在一起,當做一個整體進行處理,反向引用照常使用。

  ‘|':或(注:‘C|cat'為C與cat,‘(C|c)at才是Cat與cat')

練習題:

  1、列出當前系統(tǒng)上所有已經(jīng)登錄的用戶的用戶名,注意:同一個用戶登錄多次,則只顯示一次

[root@localhost ~]# who | cut -d' ' -f1|uniq
root

  2、取出最后登錄到當前系統(tǒng)的用戶的相關(guān)信息

[root@localhost ~]# id `last | head -1 | cut -d' ' -f1`
uid=0(root) gid=0(root) groups=0(root)

  3.取出當前系統(tǒng)上被用戶當做其默認shell最多的那個shell

[root@localhost ~]# cut -d':' -f7 /etc/passwd|uniq -c|sort -n|tail -1|cut -d' ' -f7
/sbin/nologin

  4.將/etc/passd中的第三個字段設置最大的后10個用戶的信息全部改為大寫保存至/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.取出當前主機的IP地址

[root@localhost ~]# ifconfig | egrep "inet.*broadcast.*"|cut -d' ' -f10
192.168.0.133

  6.列出/etc目錄下所有已.conf結(jié)尾的文件的文件名,并將其名字轉(zhuǎn)換為大寫后保存至/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目錄下一級子目錄或文件的總數(shù)

[root@localhost ~]# ls /var | wc -l

  8.取出/etc/group第三個字段數(shù)值最小的10個組的名字

[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)容合并為同一個內(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

總結(jié)

以上所述是小編給大家介紹的Linux grep與正則表達式,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!

您可能感興趣的文章:
  • linux 正則表達式grep實例分析
  • linux grep與正則表達式使用介紹
  • linux系統(tǒng)用戶管理與grep正則表達式示例教程
  • linux grep正則表達式與grep用法詳解
  • linux下關(guān)于正則表達式grep的一點總結(jié)

標簽:常州 大興安嶺 湖州 泰安 涼山 本溪 哈密 巨人網(wǎng)絡通訊聲明:本文標題《淺談Linux grep與正則表達式》,本文關(guān)鍵詞  淺談,Linux,grep,與,正則,表達式,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡,涉及言論、版權(quán)與本站無關(guān)。

  • 相關(guān)文章
  • 下面列出與本文章《淺談Linux grep與正則表達式》相關(guān)的同類信息!
  • 本頁收集關(guān)于淺談Linux grep與正則表達式的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章