正则表达式以及Linux文本搜索工具grep

一正则表达式

regual Expression  简称REGEXP

定义:由一类特殊字符以及文本字所编写的模式,其中有些字符不表示其字面意义,而用于统配和统配功能


分类:

    基本正则表达式:BRE 贪婪模式(尽可能长地去匹配符合模式的内容

    扩展表达式:ERE

BREERE区别:元字符不同

 基本正则表达式元字符

   字符匹配、次数匹配、位置锚定、分组及引用

   一、字符匹配

       .:匹配任意单个字符

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

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

    \d:匹配数字

     \s:匹配空格

     \w:匹配任意字母数字下划线或汉字

    

[:digit:] :0-9

[:alpha:]所有的大小写

[:upper:]:所有大写字母

[:lower:]:所有小写字母

[:alnum:]:所有字母和数字

[:punct:]:所有的标点符号

[:space:]:空格和tab

二、匹配次数:用在要指定其出现的次数的字符的后面,用于限制其前面字符出现的次数

*:匹配其前面的字符任意次;0,1,多次;

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

 \?:匹配前面的字符01

 \+:匹配前面的字符至少1

 \{m\}:匹配前面字符m

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

 

  三、位置锁定

      ^:行首锚定 ;用于模式的最左侧

     $:行尾锚定;用于模式的最右侧

          ^Pattern$:用于pattern来匹配某行

          ^$;空白行

          单词:非特殊字符组成的连续字符都称为单词

          \<\b:词首锚定,用于模式的最左侧

       \> \b:词尾锚定,用户模式的最右侧

 

 四、分组及引用(后向引用)(重点理解)

    分组符号\(\):将一个或多个字符捆绑在一起,当一个整体进行处理

    分组意义:分组括号中的模式匹配到的内容会被正则表达式引擎自动记录到内存的变量中

    引用这些变量:\1:模式从左起,第一个左括号以及与之匹配的右括号之间的模式所匹配到的字符。

 扩展的正则表达式

扩展正则表达式元字符

 字符匹配

   .:匹配任意单个字符

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

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

[:digit:] :0-9

[:alpha:]所有的大小写

[:upper:]

[:lower:]

[:alnum:]

[:punct:]

[:space:]意义和正规表达式意义相同

 

次数匹配

  *:匹配其前面的字符任意次;0,1,多次;

    .*:任意长度的任意字符,不包含换行符号

    ?:匹配前面的字符01

 +:匹配前面的字符至少1

 {m}:匹配前面字符m

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

 

位置锚定

    ^:行首锚定 ;用于模式的最左侧

    $:行尾锚定;用于模式的最右侧

    \<\b:词首锚定,用于模式的最左侧

    \> \b:词尾锚定,用户模式的最右侧

分组及引用

      分组符号()

        a|b :ab

        c|cat :Ccat

        (c|C):cat Cat

二正则表达式之应用一:grep

grep定义:

作用:文本搜索工具,根据用户指定的“模式(过滤条件)”对目标文本逐行进行匹配检查;打印匹配到的行

 模式:由正则表达式的元字符及文本字符做编写的过滤条件

全拼:Global search regular  experssion an print out the line

grep egrep fgrep:区别及之间转换

grep:支持正规的正则表达式 ;grep -E=egrep  grep -F=fgrep

egrep:支持扩展正则表达式    ;egrep -G=grep

fgrep:不支持正规表达式

用法

grep [OPTINONS]  PATTER  FILE ()

    选项

–color=auto 自动为匹配的字符着色

 

-i ignorecase 忽略字符大小写

-o:只显示字符串的本身

-v–inver –match显示不被模式匹配的行

-E 支持扩展的正则表达式

-F 支持匹配的字符串

-q 安静模式既不输出任何信息

-A 数字n:显示搜索匹配到的前n行也显示

-B 数字n:显示搜索匹配到的后n行也显示

-C 数字n:前后n行都显示

-w :以单词进行搜索

-n 显示匹配的行号

-c统计匹配的行数

   – e:实现多个选项间的逻辑or关系grep –e ‘cat ’ – e ‘dog’ file

 

grep 结合正则表达式的实例引用:

实例一:搜索文件中含有root的用户并且不区分大小写,并且只将匹配的字符打印出来

        31.png

实例二:显示含有root单词或者hello单词的行

        32.png

实例三:-q模式不将结果显示到屏幕上(一般用于脚本的编写)

35.png

实例四:grep 结合正则表达式使用,显示出含有"rt 、rot或者roo….(任意个o)t的行并显示行号36.png

实例五:分组应用 添加用户 bash、 testbash、 basher以及nologin(其shell为/sbin/nologin),而后找出 /etc/passwd文件中用户名同shell名的行

37.png

更多实例详见:

20160804课后作业



原创文章,作者:wangnannan,如若转载,请注明出处:http://www.178linux.com/30069

(0)
wangnannanwangnannan
上一篇 2016-08-07
下一篇 2016-08-07

相关推荐

  • N25-第三周作业

    1.列出当前系统所有已经登录的用户的用户名,注意同一个用户登录多次,只显示一次即可   who | cut -d" " -f1 |uniq 2.取出最后登录到当前系统的用户的相关信息    w | tail -1 3.取出当前系统上被用户当做其默认shell最多的那个shell &nbsp…

    Linux干货 2016-12-19
  • N21沉舟17周作业

    1、结合图形描述LVS的工作原理; NAT模型 NAT模型其实就是通过网络地址转换来实现负载均衡的,它的工作方式几乎跟iptables 中的DNAT一模一样的,NAT模型的工作方式: 1.用户请求VIP(也就是是CIP请求VIP) 2,Director Server 收到用户的请求后,发现源地址为CIP请求的目标地址为VIP,那么Dorector Serve…

    Linux干货 2016-11-14
  • bash基础特性的应用

    1:使用命令行展开功能来完成以下练习:     (1)、创建/tmp目录下的:a_c, a_d, b_c, b_d ~]# touch  /tmp/{a_{c,d},b_{c,d}}     (2)、创建/tmp/mylinux目录下的:      mkdir…

    Linux干货 2016-11-06
  • linux用户和用户组

    一、用户和组 1、用户账号类型 在Linux系统中,根据系统管理的需要将用户账号分为不同的类型,其拥有的权限、担任的角色也各不相同。主要包括超级用户、普通用户和程序用户。 【超级用户】:root用户是Linux系统中默认的超级用户账号,对本主机拥有最高的权限,类似于Windows系统中的Administrator用户。只有当进行系统管理、维护任务时,才建议使…

    Linux干货 2017-07-22
  • N21天天第十二周课程练习

    1、请描述一次完整的http请求处理过程; 1、建立TCP连接 2、Web浏览器向Web服务器发送请求 3、Web浏览器发送请求头信息   建立连接后,客户机发送一个请求给服务器,请求方式的格式为:统一资源标识符(URL)、协议版本号,后边是MIME   信息包括请求修饰符、客户机信息和可能的内容 4、Web服务器应答…

    Linux干货 2016-10-31
  • 文件查找命令find

      在文件系统上常常需要根据文件的各种属性去查找符合条件的文件。在Linux下也有相当优异的查找命令。今天只要将find和locate。find通常不常用,因为速度慢!通常我们先使用locate来进行模糊查找,如果真找不到了,才以find来查找。为什么呢?因为locate是利用数据库来查找数据,所以速度非常快,而且并没有实际查询硬盘比较省时间。 l…

    Linux干货 2016-08-22