linux运维实战练习-正则表达式

1、总结本此课程中所涉及命令的使用方法及相关示例展示   

      主要为正则表达式的用法,包括基本正则表达式和扩展正则表达式

2、总结基本正则表达式及扩展正则表达式

     基本正则表达式的元字符:
      字符匹配:
                       .: 匹配任意单个字符;
                    []:匹配指定范围内的任意单个字符;
                  [^]:匹配非指定范围内的任意单个字符;

                  [:lower:], [:upper:], ...

      次数匹配:用于要指定其次数的字符的后面;
                   *: 任意次;

                \?:0或1次;

               \+:1或多次; 
           \{m\}:精确限制为m次;
          \{m,n\}: 至少m次,至多n次,[m,n]
           \{0,n\}:至多n次;
            \{m,\}:至少m次;

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

      位置锚定:
                  ^: 行首锚定;用于模式的最左侧;
                  $: 行尾锚定;用于模式的最右侧;
           \<, \b: 词首锚定;用于表示单词的模式的左侧;
          \>, \b:词尾锚定;用于表示单词的模式的右侧;
                ^$: 空白行;

            分组:\(\)

                     分组的小括号中的模式匹配到的内容,会在执行过程中被正则表达式引擎记录下来,并保

                     存内置的变量中;这些变量分别是\1, \2, ...
                 \1: 从左侧起,第一个左括号,以及与之配对的右括号中间的模式所匹配到的内容;
                 \2:第二个括号内模式匹配到的内容

       后向引用:使用变量引用前面的分组括号中的模式所匹配到的字符;

       扩展正则表达式的元字符:
           字符匹配:
                         .: 任意单个字符
                        []:匹配指定范围内的任意单个字符

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

           次数匹配:
                       *:任意次数
                        ?: 0次或1次;
                       +: 1次以上;
                    {m}: 精确匹配m次;
                  {m,n}: 至少m次,至多n次;

          锚定:
                       ^: 锚定行首
                       $: 锚定行尾
              \<, \b:锚定词首
              \>, \b:锚定词尾

           分组:()
            后向引用:\1, \2, ...

           或者:
                   a|b,a或者b

3、显示/etc/passwd文件中以bash结尾的行

     # grep '--color=auto' bash$ /etc/passwd

     wKiom1XjH1niH4O5AAEbFNplosQ110.jpg

4、显示/etc/passwd文件中的两位数或三位数

      基本正则表达式  grep  "\<[1-9][0-9]\{1,2\}\>" /etc/passwd

      wKiom1XjMbTxH5PjAAH-si92AMA952.jpg

      扩展正则表达式  grep -E "\<[1-9][0-9]{1,2}\>" /etc/passwd

     

5、显示`ss -ant`命令结果中以‘LISTEN’后跟0个、1个或者多个空白字符结尾的行

    基本正则表达式  ss -ant | grep "LISTEN\(^$\)\{0,\}"

     wKiom1XjK5jRztvdAACsd1QJONI908.jpg

    扩展正则表达式 ss -ant | egrep "LISTEN(^$){0,}"

6、添加用户bash、testbash、basher以及nologin用户(nologin用户的shell为/sbin/nologin);而

      后找出/etc/passwd文件中用户名与其shell名相同的行

      扩展正则表达式:  grep -E "^([A-Za-z0-9]{1,}):.*\1$" passwd

      wKioL1XjOzyTxqakAADyBJsoQsQ784.jpg

7、显示当前系统上root、centos或者user1用户的默认shell和UID (请事先创建这些用户,若不存在)

     grep -E "^(root)|(centos)|(user1)" passwd | cut -d : -f 1,3,7

     wKioL1XjQTSzd_voAACc3ikfdjA694.jpg

8、找出/etc/rc.d/init.d/functions文件中某单词(单词中间可以存在下划线)后面跟着一组小括号的行

       egrep "\<[a-z]+_?[a-z]+\(\)" /etc/rc.d/init.d/functions

       wKioL1Xj78rgUeb5AAEWnOiLrak911.jpg

9、使用echo输出一个路径,而后egrep找出其路径基名;进一步的使用egrep取出其目录名

      echo /etc/sysconfig/test | egrep -o "^/.*"

      echo /etc/sysconfig/test | egrep -o "[^/][a-zA-Z0-9]+$"

 

     wKioL1XkUtnSQKNuAACz26y4F1Q779.jpg

       

10、 找出ip add命令执行结果中1-255之间的数字

        ip add | egrep "\<(([1-9])|([1-9][0-9])|(1[0-9]{2})|(2[0-5]{2}))\>"

         wKioL1Xj9cHCEeFXAAGQHDRnZq8567.jpg

你可能感兴趣的:(正则表达式)