正则表达式简述

bashshell中的正则表达式

        俗话说,工欲善其事,必先利其器。由于很多Linux的文本处理工具普遍使用到了正则表达式,因此,不理解正则表达式就无法愉快的从事Linux日常系统管理。那什么是正则表达式呢?

        正则表达式(RegularExpression)主要由普通字符和元字符组成。例如:键盘上的英文字母和数字都属于普通字符,普通字符可以以正常人类思维去理解,a就是英文的小写字母a,Shell没有任何隐藏含义。而^,*,#,这些比较诡异的元字符,Shell赋予了它们超越自身的意义。你可能认为*只是一个乘法符号,但实际上却表示了重复前面的字符0次或多次的隐藏含义。

        实际上,正则表达式在数据流处理的过程中完成的是数据过滤,也就是将满足正则表达式定义的数据留下来,将不满足正则表达式的数据拒绝掉。下面我们来看一看正则表达式能留住哪些元字符

正则表达式:

        *                                       匹配任意个字符,0个或多个

        .                                       匹配任意单个字符

        .*                                      匹配任意字符

        ^                                       匹配行首

        $                                       匹配行尾

        []                                      匹配字符集合

        \<\>                                    精确匹配单词符号

        \{n\}                                   匹配之前的字符n次

        \{n,\}                                  至少匹配之前的字符n次

        \{n,m\}                                 至少匹配之前的字符n次,至多m次

除了上述的正则表达式外,Linux工具中的awk,grep,perl等工具还支持扩展的正则表达式

扩展正则表达式

        ?                        匹配一个或0个在其之前的普通字符

        +                        至少匹配一个在其之前的普通字符,相当于\{1,\}

        ()                       匹配一个字符集合

        |                        表示或,用来匹配一组可选字符串

POSIX字符类

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

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

        [:alnum:]                表示所有大小写字母和数字

        [:space:]                表示空白字符

        [:alpha:]                表示所有大小写字母

        [:digit:]                表示所有数字

        [:cntrl:]                表示Ctrl键

好了,了解了这么多元字符,可以大展身手了,用到正则表达式莫过于grep,egrep,fgrep三兄弟了

grep        基本的文本查找工具,支持正则表达式

egrep       拓展grep命令,支持基本和扩展正则表达式

fgrep       快速grep命令,不支持任何正则表达式,只是按照字符的原意进行匹配

其实egrep和fgrep分别可以使用grep -E或者grep -F命令替代

       grep [OPTIONS] PATTERN [FILE…]

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

OPTIONS:

    -v        反向选取

    -o        仅显示匹配到的字符串,而非行

    -b        用于配合-o,可显示匹配到字符的偏移值

    -i        忽略字符大小写

    -E         支持拓展正则表达式

    -F         忽略所有正则表达式

    -A #      显示匹配行的后#行(#为整数)

    -B #      显示匹配行的前#行

    -C #      显示匹配行的前后各#行

PATTERN        匹配模式(当然就是由正则表达式和元字符组成啦)

FILE                查找的文件(可以由多个文件组成)

grep同时匹配的文件可以有多个,但匹配模式只能有一个

例如:当前目录有如下文件
1.PNG

输入grep root passwd?grep root bin passwd?的对比结果

2.PNG

想必细心地你也发现了FILE一项也可以使用正则表达式

例1:如果我想查找/proc/partitions中关于设备sda的相关信息,那么你可能要用到精确匹配

 grep '\<sda\>' /proc/partitions 

   8        0   20971520 sda

这样就不会匹配到sda设备下的其他分区


例2:在/etc/profile文件下有许多空白开头的行,可以使用精确匹配来获取它们

grep "^[[:space:]]\{1,\}" /etc/profile

例3:如何匹配电子邮件地址?

标准的电子邮箱地址一般为           email@mail.com

grep "[[:alnum:]]\{1,\}@[[:alnum:]]\{1,\}\.[[:alpha:]]\{2,4\}"

[[:alnum:]]\{1,\}表示在@出现之前,[]内的字符组合至少出现一次或多次,而后的[[:alnum:]]\{1,\}也是如此,\.将元字符转义成普通字符,而[[:alpha:]]\{2,4\}表示字母长度应该最少出现2次,最多出现4次


例4:想要匹配ifconfig命令中的IP地址可以使用以下方式

ifconfig | grep '[[:digit:]]\{1,3\}\.[[:digit:]]\{1,3\}\.[[:digit:]]\{1,3\}\.[[:digit:]]\{1,3\}'

3.PNG

当然这种方式也会匹配不合法的IP地址,那如果我们想匹配C类地址怎么办呢?(192.0.0.0-223.255.255.254)

  

ifconfig | egrep -o '\<(19[2-9]|2[0-1][0-9]|22[0-3])\>.\<([1-9]|[1-9][0-9]|1[0-9][0-9]|2[0-4][0-9]|25[0-5])\>.\<([1-9]|[1-9][0-9]|1[0-9][0-9]|2[0-4][0-9]|25[0-5])\>.\<([1-9]|[1-9][0-9]|1[0-9][0-9]|2[0-4][0-9]|25[0-4])\>'

4.PNG


原创文章,作者:卖糖术士,如若转载,请注明出处:http://www.178linux.com/4377

(0)
卖糖术士卖糖术士
上一篇 2015-05-20 17:16
下一篇 2015-05-23 22:14

相关推荐

  • 第五周博客作业

      感觉进入了年底,明显的时间不够,不管怎么说,还是要努力跟上学习的进度,不能给自己松懈找借口!  1、显示/boot/grub/grub.conf中以至少一个空白字符开头的行; [root@localhost ~]# grep "^[[:space:]]\+" /boot/grub/grub.co…

    Linux干货 2017-01-03
  • 【linux】正则表达式之grep、egrep、元字符

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

    Linux干货 2015-04-01
  • 文件的权限和访问控制列表

      在linux管理中,为了使不同的用户对文件有不同的操作权限。我们需要正确的修改文件的权限,一方面是为安全着想, 另一方面则是防止自己辛辛苦苦码出的东西被其它用户给误删。 1.如何修改文件的属主和属主:   前面用户和组管理的内容中,我们已经对文件的属主、属组问题做了说明。有时候我们需要对一些文件的属组和属组进行修改…

    Linux干货 2016-08-04
  • bash脚本编程练习:判断、循环

      1、写一个脚本,判断当前系统上所有用户的shell是否为可登录shell(即用户的shell不是/sbin/nologin);分别这两类用户的个数;通过字符串比较来实现; #!/bin/bash # declare -i sumlogin=0 declare -i sumnologin=0 for&nbs…

    Linux干货 2016-11-22
  • 基于mysql数据库的日志分析系统

    现如今,日志已经成为了我们分析系统及相关服务的一个重要工具。而日志也具有其相对较为固定的格式以便于进行统计查询。其大致格式如下: 日期时间            主机      &…

    Linux干货 2016-10-23
  • 第八周网络基础以及脚本联系

    1、请描述网桥、集线器、二层交换机、三层交换机、路由器的功能、使用场景与区别。 ![](http://i.imgur.com/5u2IMF8.png) 三层交换机:将路由技术和交换技术合二为一的技术,当对第一次数据流进行路由后,会产生一个MAC地址与IP地址相对应的映射表,当同样的数据流再次通过时,将根据映射表进行数据交换而不在进行路由。 路由器:工作于网络…

    Linux干货 2017-03-30