不卡AV在线|网页在线观看无码高清|亚洲国产亚洲国产|国产伦精品一区二区三区免费视频

學(xué)習(xí)啦 > 學(xué)習(xí)電腦 > 操作系統(tǒng) > Linux教程 > linuxgrep命令文本處理工具詳解

linuxgrep命令文本處理工具詳解

時(shí)間: 志藝942 分享

linuxgrep命令文本處理工具詳解

  grep(Globel Search Regular Expression and Printing out the line)全面搜索正則表達(dá)式并把行打印出來)是一種強(qiáng)大的文本搜索工具,是一個(gè)對(duì)行進(jìn)行操作的搜索工作,它能使用正則表達(dá)式搜索文本,并把匹配的行打印出來。接下來是小編為大家收集的linuxgrep命令文本處理工具詳解,歡迎大家閱讀:

  linuxgrep命令文本處理工具詳解

  Unix的grep家族包括grep、egrep和fgrep。 egrep表示擴(kuò)展的grep,相比grep支持更多的元字符,"grep -E"相當(dāng)于egrep。fgrep是fast grep,不支持元字符,但是搜索速度更快。grep搜索的結(jié)果被送到屏幕,不影響原文件內(nèi)容。

  1、grep的語法[] (man grep查看grep的幫助文檔)

  grep [options] 'pattern' FILE

  命令 選項(xiàng) 模式 文件

  grep不加引號(hào)直接過濾字符串;grep在進(jìn)行模式匹配的時(shí)候必須加引號(hào),單引和雙引號(hào)都可以;grep在引用變量的時(shí)候必須加雙引號(hào)

  2、grep的選項(xiàng)[option]

  -r:遞歸的搜索

  -v:反向選取,只顯示不符合模式的行

  -o:只顯示被模式匹配到的字符串,而不是整個(gè)行

  -i:匹配時(shí)不區(qū)分大小寫

  -A #:顯示匹配到的行時(shí),順便顯示后面的#行(#表示數(shù)值)

  -B #:前面的#行

  -C #:前后的#行

  -E:使用擴(kuò)展的正則表達(dá)式

  eg:grep選項(xiàng)的例子

  復(fù)制代碼代碼如下:

  以上代碼直接粘貼復(fù)制在linux上可直接運(yùn)行,代碼解釋運(yùn)行效果,如下

  3、 正則表達(dá)式(man regex)是指一個(gè)用來描述或者匹配一系列符合某個(gè)句法規(guī)則的字符串的單個(gè)字符串,通常被用來檢索或替換那些符合某個(gè)

  模式的文本內(nèi)容。正則表達(dá)式分為:基本正則表達(dá)式和擴(kuò)展正則表達(dá)式。

  元字符就是指那些在正則表達(dá)式中具有特殊意義的專用字符。

  grep支持基本正則表達(dá)式的元字符:

  ^:錨點(diǎn)行首的符合條件的內(nèi)容,用法格式"^pattern"

  $:錨點(diǎn)行首的符合條件的內(nèi)容,用法格式"pattern$"

  ^$:匹配空白行

  .:匹配任意單個(gè)字符

  *:匹配緊挨在前面的字符任意次(0,1,多次)

  .*:匹配任意長(zhǎng)度的任意字符

  \?:匹配緊挨在前面的字符0次或1次

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

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

  \{m\}:精確匹配前面的m次

  \{0,n\}:0到n次

  \<:錨點(diǎn)詞首----相當(dāng)于\b,用法格式:\

  \>:錨點(diǎn)詞尾,用法格式:\>pattern

  \:?jiǎn)卧~錨點(diǎn)

  \(\):分組,用法格式:\(pattern\),引用第一個(gè)小括號(hào)的分組 class="main">

學(xué)習(xí)啦 > 學(xué)習(xí)電腦 > 操作系統(tǒng) > Linux教程 > linuxgrep命令文本處理工具詳解

linuxgrep命令文本處理工具詳解

時(shí)間: 志藝942 分享
linuxgrep命令文本處理工具詳解

  grep(Globel Search Regular Expression and Printing out the line)全面搜索正則表達(dá)式并把行打印出來)是一種強(qiáng)大的文本搜索工具,是一個(gè)對(duì)行進(jìn)行操作的搜索工作,它能使用正則表達(dá)式搜索文本,并把匹配的行打印出來。接下來是小編為大家收集的linuxgrep命令文本處理工具詳解,歡迎大家閱讀:

  linuxgrep命令文本處理工具詳解

  Unix的grep家族包括grep、egrep和fgrep。 egrep表示擴(kuò)展的grep,相比grep支持更多的元字符,"grep -E"相當(dāng)于egrep。fgrep是fast grep,不支持元字符,但是搜索速度更快。grep搜索的結(jié)果被送到屏幕,不影響原文件內(nèi)容。

  1、grep的語法[] (man grep查看grep的幫助文檔)

  grep [options] 'pattern' FILE

  命令 選項(xiàng) 模式 文件

  grep不加引號(hào)直接過濾字符串;grep在進(jìn)行模式匹配的時(shí)候必須加引號(hào),單引和雙引號(hào)都可以;grep在引用變量的時(shí)候必須加雙引號(hào)

  2、grep的選項(xiàng)[option]

  -r:遞歸的搜索

  -v:反向選取,只顯示不符合模式的行

  -o:只顯示被模式匹配到的字符串,而不是整個(gè)行

  -i:匹配時(shí)不區(qū)分大小寫

  -A #:顯示匹配到的行時(shí),順便顯示后面的#行(#表示數(shù)值)

  -B #:前面的#行

  -C #:前后的#行

  -E:使用擴(kuò)展的正則表達(dá)式

  eg:grep選項(xiàng)的例子

  復(fù)制代碼代碼如下:

  以上代碼直接粘貼復(fù)制在linux上可直接運(yùn)行,代碼解釋運(yùn)行效果,如下

  3、 正則表達(dá)式(man regex)是指一個(gè)用來描述或者匹配一系列符合某個(gè)句法規(guī)則的字符串的單個(gè)字符串,通常被用來檢索或替換那些符合某個(gè)

  模式的文本內(nèi)容。正則表達(dá)式分為:基本正則表達(dá)式和擴(kuò)展正則表達(dá)式。

  元字符就是指那些在正則表達(dá)式中具有特殊意義的專用字符。

  grep支持基本正則表達(dá)式的元字符:

  ^:錨點(diǎn)行首的符合條件的內(nèi)容,用法格式"^pattern"

  $:錨點(diǎn)行首的符合條件的內(nèi)容,用法格式"pattern$"

  ^$:匹配空白行

  .:匹配任意單個(gè)字符

  *:匹配緊挨在前面的字符任意次(0,1,多次)

  .*:匹配任意長(zhǎng)度的任意字符

  \?:匹配緊挨在前面的字符0次或1次

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

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

  \{m\}:精確匹配前面的m次

  \{0,n\}:0到n次

  \<:錨點(diǎn)詞首----相當(dāng)于\b,用法格式:\

  \>:錨點(diǎn)詞尾,用法格式:\>pattern

  \:?jiǎn)卧~錨點(diǎn)

  \(\):分組,用法格式:\(pattern\),引用第一個(gè)小括號(hào)的分組\1,第二個(gè)是\2,以此類推

  []:匹配指定范圍內(nèi)的任意單個(gè)字符

  [^]:匹配指定范圍外的任意單個(gè)字符

  eg:基本正則表達(dá)的例子

  (1)、顯示/proc/meminfo文件中以不區(qū)分大小的s開頭的行;

  grep "^[sS]" /proc/meminfo

  (2)、顯示/etc/passwd中以nologin結(jié)尾的行;

  grep "nologin$" /etc/passwd

  (3)、顯示/etc/inittab中空格開頭的行;

  grep "^$" /etc/inittab

  (4)、顯示/etc/passwd中,以r開頭的字符而后跟了任意單個(gè)字符的行;

  grep --color "^r." /etc/passwd

  (5)、顯示/etc/passwd中,以r開頭后跟了o,o出現(xiàn)任意次的行;

  grep --color "^ro*" /etc/passwd

  (6)、顯示/etc/passwd文件中,r后跟了任意長(zhǎng)度任意字符后跟了h的行;

  grep --color "r.*h" /etc/passwd

  (7)、顯示/etc/passwd中,r后跟了o,o出現(xiàn)0次或者1次的行;

  grep --color "ro\?" /etc/passwd

  (8)、顯示/etc/passwd中,r后跟了o,o出現(xiàn)至少1次至多2次的行;

  grep --color "ro\{1,2\}" /etc/passwd

  (9)、顯示/etc/passwd中,r后跟了o,o只出現(xiàn)2次的行;

  grep --color "ro\{2\}" /etc/passwd

  (10)、顯示/etc/passwd中,匹配root這個(gè)單詞的行;

  grep --color "\" /etc/passwd

  grep支持?jǐn)U展表達(dá)式的元字符:支持所有基本正則表達(dá)式的元字符,有些和基本元字符在用法上不一樣,擴(kuò)展正則表達(dá)式的命令egrep或者grep -E

  ?:匹配緊挨在前面的字符0次或1次

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

  ():分組

  +:至少匹配前面的字符一次

  a|b:匹配a或者b

  eg:擴(kuò)展正則表達(dá)式的例子

  (1)、顯示/etc/passwd中,r開頭后跟了o,o出現(xiàn)0次或者1次的行;

  egrep --color "ro?" /etc/passwd

  (2)、顯示/etc/passwd中,r開頭后跟了o,o出現(xiàn)至少1次至多2次的行;

  egrep --color "ro{1,2}" /etc/passwd

  (3)、顯示/etc/inittab文件中以一個(gè)數(shù)字開頭并以一個(gè)與開頭數(shù)字相同的數(shù)字結(jié)尾的;

  egrep --color "^([0-9]).*\1$" /etc/inittab

 
 看了“linuxgrep命令文本處理工具詳解”還想看:

1.Linux文本匹配命令grep與fgrep使用全解

2.linux grep搜索命令的使用方法

3.14個(gè)grep命令使用例子介紹

4.Linux下如何使用grep命令搜索多個(gè)單詞

,以此類推

  []:匹配指定范圍內(nèi)的任意單個(gè)字符

  [^]:匹配指定范圍外的任意單個(gè)字符

  eg:基本正則表達(dá)的例子

  (1)、顯示/proc/meminfo文件中以不區(qū)分大小的s開頭的行;

  grep "^[sS]" /proc/meminfo

  (2)、顯示/etc/passwd中以nologin結(jié)尾的行;

  grep "nologin$" /etc/passwd

  (3)、顯示/etc/inittab中空格開頭的行;

  grep "^$" /etc/inittab

  (4)、顯示/etc/passwd中,以r開頭的字符而后跟了任意單個(gè)字符的行;

  grep --color "^r." /etc/passwd

  (5)、顯示/etc/passwd中,以r開頭后跟了o,o出現(xiàn)任意次的行;

  grep --color "^ro*" /etc/passwd

  (6)、顯示/etc/passwd文件中,r后跟了任意長(zhǎng)度任意字符后跟了h的行;

  grep --color "r.*h" /etc/passwd

  (7)、顯示/etc/passwd中,r后跟了o,o出現(xiàn)0次或者1次的行;

  grep --color "ro\?" /etc/passwd

  (8)、顯示/etc/passwd中,r后跟了o,o出現(xiàn)至少1次至多2次的行;

  grep --color "ro\{1,2\}" /etc/passwd

  (9)、顯示/etc/passwd中,r后跟了o,o只出現(xiàn)2次的行;

  grep --color "ro\{2\}" /etc/passwd

  (10)、顯示/etc/passwd中,匹配root這個(gè)單詞的行;

  grep --color "\" /etc/passwd

  grep支持?jǐn)U展表達(dá)式的元字符:支持所有基本正則表達(dá)式的元字符,有些和基本元字符在用法上不一樣,擴(kuò)展正則表達(dá)式的命令egrep或者grep -E

  ?:匹配緊挨在前面的字符0次或1次

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

  ():分組

  +:至少匹配前面的字符一次

  a|b:匹配a或者b

  eg:擴(kuò)展正則表達(dá)式的例子

  (1)、顯示/etc/passwd中,r開頭后跟了o,o出現(xiàn)0次或者1次的行;

  egrep --color "ro?" /etc/passwd

  (2)、顯示/etc/passwd中,r開頭后跟了o,o出現(xiàn)至少1次至多2次的行;

  egrep --color "ro{1,2}" /etc/passwd

  (3)、顯示/etc/inittab文件中以一個(gè)數(shù)字開頭并以一個(gè)與開頭數(shù)字相同的數(shù)字結(jié)尾的;

  egrep --color "^([0-9]).* class="main">

2990954