【linux】正则表达式之grep、egrep、元字符

正则表达式:

    又称正规表示法、常规表示法(英语:Regular Expression,在代码中常简写为regex、regexp或RE),计算机科学的一个概念。是一类字符所书写的模式,其中许多字符(元字符)不表示其字面意义,而是表达控制或通配等功能。正则表达式使用单个字符串来描述、匹配一系列符合某个句法规则的字符串。在很多文本编辑器里,正则表达式通常被用来检索、替换那些符合某个模式的文本。

语法:

    grep [OPTIONS] PATTERN [FILE…]

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

    如:/etc/passwd中以root开头的行,及其后面的两行

   blob.png

    -A 2为OPTIONS,命令选项;^root为PATTERN,其中root为字面意思,^为元字符;/etc/passwd为FILE

正则表达式分类:

    根据元字符数量及功能的不同分为基本正则表达式(grep)、扩展正则表达式(egrep)。grep和egrep都是文本搜索工具,可根据用户指定的文本模式(搜索条件,即:文本+元字符)对目标文件进行逐行搜索,显示能匹配到的行;用法上grep -E等同于egrep。此外还有一个文本搜索工具fgrep,不支持正则表达式,没有自己的元字符,不做详细解释。

    在搜索工具中,元字符起到至关重要的作用;元字符即,不表示其字面意义,而用于额外功能性描述。

正则表达式元字符:

    grep元字符:

        1.字符匹配:

        .: 匹配任意单个字符

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

        [0-9], [[:digit:]]

        [a-z], [[:lower:]]

        [A-Z], [[:upper:]]

        [[:space:]]匹配空白字符,包括空格,tab…

            Space characters (such as space, tab, and formfeed, to  name a few).

            tab, newline, vertical tab, form feed, carriage return, and space. 

        [[:punct:]]匹配任意标点符号:: '! " # $ % & ' ( ) * + , – . / : ; < = > ? @ [ \ ] ^ _ ' { | } ~'. 

            Punctuation characters (characters that are not letter, digits, control characters, or space characters).

        [[:alpha:]]字母数字符

        Alphabetic characters.

        [[:alnum:]]匹配任何字母 

        Alphanumeric characters.

        [^]:代表本表达式不匹配"[]"内出现的字符

        2.次数匹配元字符:

    用于实现指定其前面的字符所能够出现的次数

    *: 任意长度,它前面的字符可以出现任意次

    \?: 0次或1次,它前面的字符是可有可无的

    \{m\}: m次,它前的字符要出现m次

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

    \{m,\}:至少m次

    \{0,n\}: 至多n次

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

        3.位置锚定:

    ^: 行首锚定;写在模式最左侧

    $: 行尾锚定:写在模式最右侧

    ^$: 空白行

        4.分组:

    \(\)

    例如:\(ab\)*

    分组中的模式匹配到的内容,可由正则表达式引擎记忆在内存中,之后可被引用

        5.引用:

    例如\(ab\(x\)y\).*\(mn\)

    有编号:自左而后的左括号,以及与其匹配右括号

    \(a\(b\(c\)\)mn\(x\)\).*\1

    \#: 引用第n个括号所匹配到的内容,而非模式本身

    例如:      blob.png

    引用第一个分组的内容为\(w\(es\)t\)

    引用第二个分组的内容为\(es\)

    也可以看出正则表达式是工作在贪婪模式下,会尽可能多的匹配

        6.补充:

    不包含特殊字符的连续字符组成的串叫单词:

    \<: 词首,出现于单词左侧,\b

    如:\<char

    \>: 词尾,出现于单词右侧, \b

    如:char\>

    egrep元字符:

        1.字符匹配:

    .:任意单个字符

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

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

        2.次数匹配:

    *:任意次

    ?: 0次或1次

    +: 至少1次;

    {m}: 精确匹配m次

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

    {m,}:至少m次

    {0,n}:至多n次

        3.锚定:

    ^:行首

    $:行尾

    ^$, ^[[:space:]]*$:空白行

        4.分组:

    ()

        5.引用:

    \1, \2, \3

        6.或者:

    a|b: a或者b

    con(C|c)at

        7.补充

    \<, \b

    \>, \b

    grep与egrep区别

        grep的扩充版本, 改良了许多传统 grep 不能或不便的操作. 比方说:

        grep 之下不支持 ? 与 + 这两种 modifier, 但 egrep 则可.

     blob.png

        grep 不支持 a|b 或 (abc|xyz) 这类"或一"比对, 但 egrep 则可.        blob.png

        grep 在处理 {n,m} 时, 需用 \{ 与 \} 处理, 但 egrep 则不需.      blob.png

    fgrep:特别搜索

        无元字符,字符表示字面意思。

命令选项:

    -v: 反向选取,即不包含

    -o: 仅显示匹配的字串,而非字串所在的行

    -i: ignore-case,忽略字符大小写

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

    -A #:Print  NUM  lines of trailing context after matching lines.

    -B #:Print NUM lines of leading context before matching lines.

    -C #:Print NUM lines of output context.  Places a line containing a group separator (–) between contiguous groups of matches.


根据马哥随笔,参考(http://www.178linux.com/archives/1198、http://blog.sina.com.cn/s/blog_51dc0fba0100lqu8.html)及度娘整理。

初次发博客,如有遗漏、错误烦请告知~


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

(0)
jiangyali518jiangyali518
上一篇 2015-04-01
下一篇 2015-04-01

相关推荐

  • 如何自建系统内部 yum 仓库

       准备:     a.素材:一套centos6.9和一套centos7.3的ISO镜像光盘     环境:1.centos6.9和centos7.3,安装好的系统各一套(土豪随意 )     b.建立前请关闭防火墙,防止防火墙的干扰     &n…

    2017-08-05
  • Linux安全与加密基础(一)

    Linux安全与加密基础(一) 常见的加密算法 SSL: Openssl与CA认证 ssh服务 dropbear AIDE sudo 常见的加密算法 密码学古以有之,尤其是在中国古代的战争中,在现在科技中,密码学不得不说是一门高深的学问,普通人知其一二足矣;本文要讨论的是关于加密与解密的基本原理与应用,以及关于Linux系统中的一些安全管理问题,如ssh服务…

    Linux干货 2016-10-06
  • 推荐-BtrFS学习总结

    一、原理介绍1.可扩展性2.数据一致性的相关特性3.多设备管理及快照二、命令介绍与实战1.命令介绍2.命令实战1)环境准备,添加3块磁盘/dev/sd{b,c,d}如下:2)创建btrfs文件系统3)查看已创建的btrfs文件系统4)挂载btrfs文件系统,启用压缩功能5)在线调整文件系统大小6)往当前btrfs文件系统添加设备,以达到在线扩容扩容目的7)执…

    Linux干货 2016-06-03
  • 文本处理三剑客之awk

    一、知识整理 1、awk报告生成器,格式化文本输出 发明人:a.k.a. Aho,Kernighan,weinberger awk程序通常由:BEGIN语句块、能够使用模式匹配的通用语句块、END语句块三部分组成。program通常是放在单引号或双引号中。 基本用法:awk [] ‘program’ var=value fiel… pr…

    Linux干货 2016-09-26
  • shell脚本编程的一些好习惯

    shell脚本编程的一些好习惯 1.命名规则   脚本命名以.sh结尾,名称尽量见名之意。以下是几种可供参考的脚本命名风格。通过以下清新脱俗的风格,读者能够很easy的明白脚本的作用。 clearlog.sh ClearLog.sh clearSql.sh snmp_install.sh Monitor.sh 2.脚本信息   为脚本加入…

    Linux干货 2017-04-14
  • RHCE系列之备份工具—-镜像备份Rsync

    原创作品,允许转载,转载时请务必以超链接形式标明文章 原始出处 、作者信息和本声明。否则将追究法律责任。http://nolinux.blog.51cto.com/4824967/1431426     我一哥们最近在搞备份,需要用到rsync。因此,鄙人就简单总结了下rsync,也就有了这篇博文,希望对51…

    Linux干货 2016-08-15

评论列表(2条)

  • stanley
    stanley 2015-04-02 22:04

    较上次好了很多,如果能加上段落的标识,代码的格式化,颜色的标识会更好.加油

    • jiangyali518
      jiangyali518 2015-04-02 23:31

      @stanleywhatever,确实不足。感谢提点,会向您提的方向努力~感谢。