zoukankan      html  css  js  c++  java
  • 07 grep命令与正则表达式

     

    grep命令

      首先我们知道grep命令是用来做文件内容过滤的!如果你要在文件中查找一些对应的内容,我们如何来过滤找到其中我们需要符合条件的内容呢?grep命令结合正则表达式就可以实现;

      grep、egrep以及fgrep为一组命令,其中grep为命令本身,而grep -E(支持扩展的正则表达式),fgrep就是什么都支持(fast grep)在某些条件下实现快速查找;这里我们详细介绍grep命令;

      grep的使用方式:grep [OPTIONS] PATTERN [FILE...]

      pattern 模式:这里的模式,文本字符、正则表达式的元字符组而成的一个匹配条件,就是我们的pattern;

      grep是以块来匹配,只要这一行包含匹配字符,这一行的内容在默认情况下都会显示出来;

      -o  只有匹配的字符才会显示,不会再直接显示整行的内容;

      -v  反向选择,匹配pattern里面没有包含的内容

      -i  字母不区分大小写

      为了匹配更为复杂的内容,我们将pattern的内容结合正则表达式来进行匹配,下面我们就具体介绍下正则表达式:

    正则表达式

      Regular EXPression,REGEXP

      正则表达式就是使用一些元字符,他们不表示自己原本的意义,而是使用这些元字符的通配含义!【一定要区分正则表达式中的通配符,与文件名通配符的区别!】

      文件名通配符【非正则表达式】:

        *  表示任意长度的任意字符

        ?  任意的单个字符

        []  文件匹配范围

        [^]  文件匹配范围取反

      基本正则表达式通配符含义:

      1、字符匹配:

        .  表示任意单个字符

        *  匹配前面一个字符,任意长度

          a* 这就表示匹配a、aa、aaa等【.* 在正则表达式里面是匹配任意字符的意思】

        ?  匹配前面的字符1次后者0次【* 表示匹配前面的字符任意次】

        {m,n}  匹配前面的字符最少m次,最多n次

          {1,}  匹配前面的字符最少一次

          {0,3}  匹配前面的字符最少0次,最多3次

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

          grep --color [ab] /etc/inittab  #匹配a或则b字符

        [^]  匹配范围外的字符

          grep --color [^ab] /etc/inittab  #匹配除了ab字符外的所有字符

      2、位置锚定符号:

        ^  锚定行首,指定文件以什么内容开头

        $  锚定行位,指定文件以什么内容结尾

        ^$  表示空白行

        <  其后面的任意字符必须作为单词的首部出现

        >  其后面的任意字符必须作为单词的尾部出现

          <root>  #以root开头的单词,且以root结尾的单词,abrroot、rootabc这两个字符串就无法匹配上;

          放在开头,则是<锚定单词首部,放在后面,则是>锚定单词尾部

      3、分组:

        ()  例如:(ab)*和ab*的区别,前者是ab一起重复任意次,而后者则是b重复任意次;前者将ab视为了一个整体!

        1  引用第一个左括号以及第一个右括号括起来的组参数

        2  引用第二个左括号的以及第二个右括号括起来的组参数

        3 、4、5 ... 依此类推

      

     

  • 相关阅读:
    优达,计算机科学导论
    关于未来发展阶段小结
    CS50.5
    CS50.4
    简单查看tomcat中部署java服务的内存使用情况
    python3环境搭建(CentOS7.2)
    mysql主从配置脚本
    安装rkhunter
    转移到博客园啦!
    Eclipse上Maven环境配置使用 (全)
  • 原文地址:https://www.cnblogs.com/BurnovBlog/p/10343114.html
Copyright © 2011-2022 走看看