学习啦>学习电脑>操作系统>Linux教程>

linuxgrep命令文本处理工具详解

志艺分享

  grep(Globel Search Regular Expression and Printing out the line)全面搜索正则表达式并把行打印出来)是一种强大的文本搜索工具,是一个对行进行操作的搜索工作,它能使用正则表达式搜索文本,并把匹配的行打印出来。接下来是小编为大家收集的linuxgrep命令文本处理工具详解,欢迎大家阅读:

  linuxgrep命令文本处理工具详解

  Unix的grep家族包括grep、egrep和fgrep。 egrep表示扩展的grep,相比grep支持更多的元字符,"grep -E"相当于egrep。fgrep是fast grep,不支持元字符,但是搜索速度更快。grep搜索的结果被送到屏幕,不影响原文件内容。

  1、grep的语法[] (man grep查看grep的帮助文档)

  grep [options] 'pattern' FILE

  命令 选项 模式 文件

  grep不加引号直接过滤字符串;grep在进行模式匹配的时候必须加引号,单引和双引号都可以;grep在引用变量的时候必须加双引号

  2、grep的选项[option]

  -r:递归的搜索

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

  -o:只显示被模式匹配到的字符串,而不是整个行

  -i:匹配时不区分大小写

  -A #:显示匹配到的行时,顺便显示后面的#行(#表示数值)

  -B #:前面的#行

  -C #:前后的#行

  -E:使用扩展的正则表达式

  eg:grep选项的例子

  复制代码代码如下:

  以上代码直接粘贴复制在linux上可直接运行,代码解释运行效果,如下

  3、 正则表达式(man regex)是指一个用来描述或者匹配一系列符合某个句法规则的字符串的单个字符串,通常被用来检索或替换那些符合某个

  模式的文本内容。正则表达式分为:基本正则表达式和扩展正则表达式。

  元字符就是指那些在正则表达式中具有特殊意义的专用字符。

  grep支持基本正则表达式的元字符:

  ^:锚点行首的符合条件的内容,用法格式"^pattern"

  $:锚点行首的符合条件的内容,用法格式"pattern$"

  ^$:匹配空白行

  .:匹配任意单个字符

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

  .*:匹配任意长度的任意字符

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

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

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

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

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

  \<:锚点词首----相当于\b,用法格式:\

  \>:锚点词尾,用法格式:\>pattern

  \:单词锚点

  \(\):分组,用法格式:\(pattern\),引用第一个小括号的分组 class="con">

linuxgrep命令文本处理工具详解

志艺分享

  grep(Globel Search Regular Expression and Printing out the line)全面搜索正则表达式并把行打印出来)是一种强大的文本搜索工具,是一个对行进行操作的搜索工作,它能使用正则表达式搜索文本,并把匹配的行打印出来。接下来是小编为大家收集的linuxgrep命令文本处理工具详解,欢迎大家阅读:

  linuxgrep命令文本处理工具详解

  Unix的grep家族包括grep、egrep和fgrep。 egrep表示扩展的grep,相比grep支持更多的元字符,"grep -E"相当于egrep。fgrep是fast grep,不支持元字符,但是搜索速度更快。grep搜索的结果被送到屏幕,不影响原文件内容。

  1、grep的语法[] (man grep查看grep的帮助文档)

  grep [options] 'pattern' FILE

  命令 选项 模式 文件

  grep不加引号直接过滤字符串;grep在进行模式匹配的时候必须加引号,单引和双引号都可以;grep在引用变量的时候必须加双引号

  2、grep的选项[option]

  -r:递归的搜索

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

  -o:只显示被模式匹配到的字符串,而不是整个行

  -i:匹配时不区分大小写

  -A #:显示匹配到的行时,顺便显示后面的#行(#表示数值)

  -B #:前面的#行

  -C #:前后的#行

  -E:使用扩展的正则表达式

  eg:grep选项的例子

  复制代码代码如下:

  以上代码直接粘贴复制在linux上可直接运行,代码解释运行效果,如下

  3、 正则表达式(man regex)是指一个用来描述或者匹配一系列符合某个句法规则的字符串的单个字符串,通常被用来检索或替换那些符合某个

  模式的文本内容。正则表达式分为:基本正则表达式和扩展正则表达式。

  元字符就是指那些在正则表达式中具有特殊意义的专用字符。

  grep支持基本正则表达式的元字符:

  ^:锚点行首的符合条件的内容,用法格式"^pattern"

  $:锚点行首的符合条件的内容,用法格式"pattern$"

  ^$:匹配空白行

  .:匹配任意单个字符

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

  .*:匹配任意长度的任意字符

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

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

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

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

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

  \<:锚点词首----相当于\b,用法格式:\

  \>:锚点词尾,用法格式:\>pattern

  \:单词锚点

  \(\):分组,用法格式:\(pattern\),引用第一个小括号的分组\1,第二个是\2,以此类推

  []:匹配指定范围内的任意单个字符

  [^]:匹配指定范围外的任意单个字符

  eg:基本正则表达的例子

  (1)、显示/proc/meminfo文件中以不区分大小的s开头的行;

  grep "^[sS]" /proc/meminfo

  (2)、显示/etc/passwd中以nologin结尾的行;

  grep "nologin$" /etc/passwd

  (3)、显示/etc/inittab中空格开头的行;

  grep "^$" /etc/inittab

  (4)、显示/etc/passwd中,以r开头的字符而后跟了任意单个字符的行;

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

  (5)、显示/etc/passwd中,以r开头后跟了o,o出现任意次的行;

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

  (6)、显示/etc/passwd文件中,r后跟了任意长度任意字符后跟了h的行;

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

  (7)、显示/etc/passwd中,r后跟了o,o出现0次或者1次的行;

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

  (8)、显示/etc/passwd中,r后跟了o,o出现至少1次至多2次的行;

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

  (9)、显示/etc/passwd中,r后跟了o,o只出现2次的行;

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

  (10)、显示/etc/passwd中,匹配root这个单词的行;

  grep --color "\" /etc/passwd

  grep支持扩展表达式的元字符:支持所有基本正则表达式的元字符,有些和基本元字符在用法上不一样,扩展正则表达式的命令egrep或者grep -E

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

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

  ():分组

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

  a|b:匹配a或者b

  eg:扩展正则表达式的例子

  (1)、显示/etc/passwd中,r开头后跟了o,o出现0次或者1次的行;

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

  (2)、显示/etc/passwd中,r开头后跟了o,o出现至少1次至多2次的行;

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

  (3)、显示/etc/inittab文件中以一个数字开头并以一个与开头数字相同的数字结尾的;

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

 
 看了“linuxgrep命令文本处理工具详解”还想看:

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

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

3.14个grep命令使用例子介绍

4.Linux下如何使用grep命令搜索多个单词

,以此类推

  []:匹配指定范围内的任意单个字符

  [^]:匹配指定范围外的任意单个字符

  eg:基本正则表达的例子

  (1)、显示/proc/meminfo文件中以不区分大小的s开头的行;

  grep "^[sS]" /proc/meminfo

  (2)、显示/etc/passwd中以nologin结尾的行;

  grep "nologin$" /etc/passwd

  (3)、显示/etc/inittab中空格开头的行;

  grep "^$" /etc/inittab

  (4)、显示/etc/passwd中,以r开头的字符而后跟了任意单个字符的行;

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

  (5)、显示/etc/passwd中,以r开头后跟了o,o出现任意次的行;

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

  (6)、显示/etc/passwd文件中,r后跟了任意长度任意字符后跟了h的行;

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

  (7)、显示/etc/passwd中,r后跟了o,o出现0次或者1次的行;

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

  (8)、显示/etc/passwd中,r后跟了o,o出现至少1次至多2次的行;

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

  (9)、显示/etc/passwd中,r后跟了o,o只出现2次的行;

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

  (10)、显示/etc/passwd中,匹配root这个单词的行;

  grep --color "\" /etc/passwd

  grep支持扩展表达式的元字符:支持所有基本正则表达式的元字符,有些和基本元字符在用法上不一样,扩展正则表达式的命令egrep或者grep -E

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

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

  ():分组

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

  a|b:匹配a或者b

  eg:扩展正则表达式的例子

  (1)、显示/etc/passwd中,r开头后跟了o,o出现0次或者1次的行;

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

  (2)、显示/etc/passwd中,r开头后跟了o,o出现至少1次至多2次的行;

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

  (3)、显示/etc/inittab文件中以一个数字开头并以一个与开头数字相同的数字结尾的;

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

2990954