grep是个什么鬼

正则表达式

  一个正则表达式是一个描述了一个字符串集合的模式。正则表达式的构造类似于算术表达式,使用各种各样的操作符来将更小的表达式连在一起。

Grep能理解两种不同版本的正则表达式语法:“basic”和“extended”。在GNU grep中,两种语法可以实现的功能是没有区别的。在其他实现中,基本(basic)正则表达式表达能力要弱一点。下面的描述适用于扩展的(extended)正则表达式,它与基本正则表达式的区别会在最后做一个总结。

基本的构造块是匹配单个字符的正则表达式。大部分字符,包括所有字母和数字,是匹配它们自身的正则表达式。任何具有特殊含义的元字符可以通过前置一个反斜杠来引用。

1元字符

方括号表达式(bracket)是一个字符序列,放在 [ ] 当中。它匹配序列中的任何一个字符;如果序列中的第一个字符是脱字符(caret) ^ 那么它匹配不在序列中的任何一个字符。例如,正则表达式 [0123456789] 匹配任何一个数字。

在方括号表达式之中,一个范围表达式(range)由两个字符组成,中间用一个连字符    (hyphen)分隔。它匹配在这两个字符之间的任何一个字符,使用本地化的序列顺序和字符集。(that sorts between the two characters,inclusive, using the locale’s  collating sequence and character set.)  例如,在默认的  C locale中,[a-d][abcd]等价。

许多 locale 将字符以字典顺序排序,在这些 locale 中,[a-d]不与[abcd]等价;例如它可能与[aBbCcDd]等价。

  最后,在方括号表达式中有一些预定义 的字符类,如下所示。它们的名字是自说明的,它们是[:alnum:](字母和数字), [:alpha:](字母), [:cntrl:](控制字符), [:digit:](数字), [:graph:](图形字符), [:lower:](小写字母),[:print:](可打印字符),[:punct:](标点符号),[:space:](空格),[:upper:](大写字母),[:xdigit:](十六进制数字)

[:alnum:]

字母和数字

[:cntrl:]

控制字符

[:alpha:]

字母

[:print:]

可打印字符

[:lower:]

小写字母

[:punct:]

标点符号

[:upper:]

大写字母

[:space:]

空格

[:digit:]

数字

[:graph:]

图形字符

[:xdigit:]

十六进制数字

例如, [[:alnum:]] 意思是[0-9A-Za-z],但是后一种表示方法依赖于  locale CASCII字符编码,而前一种是与locale和字符集无关的。(注意这些字符类名中的方括号也是符号名称的一部分,必须包含在用来为序列定界的方括号之中。)

  大多数元字符处于序列中时会失去它们的特殊意义。为了包含一个字面意义(literal)的 ,需要将它放在序列的最前。与此相似,为了包含一个字面意义(literal)^,需要将它放在除了序列最前之外的其他位置。最后,为了包含一个字面意义(literal) 需要将它放在序列最后。

   句点符(period)  .  匹配任何一个字符。符号\w[[:alnum:]]的同义词,\W[^[:alnum]]的同义词。

   脱字符(caret)^和美元标记(dollar)$分别是匹配一行的首部和尾部的空字串的元字符。

   符号\<\>分别是匹配一个词的首部和尾部的空字串的元字符。

   符号\b匹配一个词边缘(edge)的空字串,符号\B匹配不处于一个词的边缘的空字串

2重复操作符

  一个正则表达式后面可以跟随多种重复操作符之一。

   ? 前的项是可选的,最多匹配一次。

   * 前的项可以匹配零次或多次。

   + 前的项可以匹配一次或多次。

   {n} 前的项将匹配恰好n次。

   {n,} 前的项可以匹配n或更多次。

   {n,m} 前的项将匹配至少n词,但是不会超过m次。

  两个正则表达式可以连接到一起;得出的正则表达式可以匹配任何由两个分别匹配连接前的子表达式的子字符串连接而成的字符串。两个正则表达式可以用中缀操作符|将它们联合到一起,得出的正则表达式可以匹配任何匹配联合前的任何一个子表达式的字符串。

 重复操作符的优先级比连接高,接下来又比选择的优先级高。一个完整的子表达式可以用圆括号(parentheses)括住来超越这些优先级规则。反向引用 \n 中, n 是一个数字,匹配正则表达式中,以第 n 个圆括号括住的子表达式已匹配的子字符串。

在基本正则表达式中,元字符  ?,  +,  {, |, (, ) 丧失了它们的特殊意义;作为替代,使用加反斜杠的 (back]2slash) 版本 \?, \+, \{, \|, \(, \)

  传统的 egrep 不支持元字符 { ,并且一些 egrep 的实现通过支持  \{  来代替它,因此可移植的脚本应当避免在egrep 中使用 { 模式,应当使用 [{] 来匹配一个字面意义 (literal) { (上面提到大部分元字符放入方括号中会失去特殊意义)

  

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

(0)
TQTTQT
上一篇 2017-04-17
下一篇 2017-04-17

相关推荐

  • 马哥教育网络班21期第7周课程练习

    1、创建一个10G分区,并格式为ext4文件系统;    (1) 要求其block大小为2048, 预留空间百分比为2, 卷标为MYDATA, 默认挂载属性包含acl;    (2) 挂载至/data/mydata目录,要求挂载时禁止程序自动运行,且不更新文件的访问时间戳; [root@centos7study&nbs…

    Linux干货 2016-08-29
  • [转]百万级访问网站前期的技术准备

       [转]百万级访问网站前期的技术准备 开了自己域名的博客,第一篇就得来个重磅一点的才对得起这4美金的域名。作为一个技术从业者十年,逛了十年发现有些知识东一榔头西一棒槌的得满世界  看个遍才整理出个头绪,那咱就系统点的从头一步一步的说,一个从日几千访问的小小网站,到日访问一两百万的小网站,怎么才能让它平滑的度过这个阶段,别在 …

    Linux干货 2016-10-29
  • liunx性能监控工具总结

    1.uptime 1)显示的信息:显示当前时间,系统已启动的时间,当前在线人数,系统平均负载(1分钟、5分钟、10分钟的平均负载,一般不会超过1) 2)系统平均负载:指在特定时间间隔内运行队列中的平均进程数。 3)如果每个CPU内核的当前活动进程数不大于3的话,那么系统的性能良好。如果每个CPU内核的任务数大于5,那么这台及其的性能有严重问题 4)ruguo…

    Linux干货 2016-09-09
  • yum的简单配置与使用

    yum 的基本配置与使用 1、yum:是rpm包管理器的前端工具,它是基于C/S结构,就客户端服务器模式 2、yum使用前需先配置好服务端的仓库(yum源) 3、yum客户端是通过文件传输协议来获取到yum源上的软件包的,yum一共支持四种传输协议 http:// https:// ftp:// file:// (这是一个本地路径,当yum源为本地光盘时,使…

    Linux干货 2017-06-11
  • Linux系统启动流程

        下面按照系统的启动顺序来进行逐一的讲解。 一、POST     当我们按下开机的电源后,主板上的芯片组会首先向CPU发出一个reset指令,之后待芯片组检测到电源供电稳定后便撤去reset指令,CPU就会跳转到BIOS中的启动代码位置; BIOS首先要检测关键设备(如内显…

    Linux干货 2015-05-23
  • 从零开始搭建双主模型的nginx proxy高可用集群

    实验简介 本文主要介绍双主模型的nginx proxy高可用集群的搭建方式。实验环境: 使用nfs/ftp服务器,nfs提供页面数据共享,ftp提供程序下载 使用单独的mariadb服务器提供关系型数据库 使用两台httpd服务器提供页面服务,包括静态的html和动态的php(phpmyadmin、wordpress、phpinfo) 使用两台nginx作为…

    Linux干货 2017-06-25

评论列表(1条)

  • renjin
    renjin 2017-04-21 11:09

    主要介绍了grep命令中的正则表达式的用法 ,内容介绍的很详细,可以适当的加几个示例进来