初学正则表达式

  前言:

    在学正则表达式之前,有小伙伴讲解说,正则表达式在文本处理上功能非常强大、使用非常普遍,并且现在很多的工具软件都支持它,以后的学习工作中会经常使用,非常灵活,但是灵活的同时又是繁琐,需要小心翼翼的仔细推敲。抱着认真、好奇的心思听完了王老的课。我自己理解的正则表达式是,给一些符号赋予一定的涵义,代表一个我们规定的特殊涵义,然后通过我们的要求的字段进行这些字符的组合,组合成符合我们条件的一个字符表达式,然后用这个字符条件表达式去目的文本中对应搜索,有匹配的就显示标记出来。学习之后,感觉确实非常灵活和强大,各种的文本中会出现的符号都给予了定义,能通过这些字符进行灵活的排列组合,得到我们想要的字段。但是在强大和灵活的同时,感觉又比较繁琐,各种符号的组合。感觉应该是一个需要经常训练,熟能生巧的一个知识,就好像上学时候的题海战术,用的多了,练得多了,见得多了,用起来应该会比较顺手和灵活的。自己感觉这个知识点要多做多练多看多学习,由于组合太多,也许能够通过组合得到相应的目的表达式,但是这么灵活的正则表达式,难道没有更简洁更直观更有趣的排列组合方式吗,只能通过多看多做多练习,慢慢体味其中排列组合的乐趣。

   正则表达式是通过一些特殊字符的排列,用以查找、替换、删除一行或多行文字字符串,通俗的说,正则表达式就是用在字符串的处理上面的一项“表达式”

   在学习正则表达式之前,先看看支持正则表达式的几个命令,首先是支持基本正则表达式的命令grep,然后是扩展正则表达式egrep和fgrep

一、都支持的常用特殊字符

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

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

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

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

    [:punct:]  表示所有标点字符

    [:digit:]  表示所有数字

    [:space:]  表示所有能产生空白的字符,包括空格、tab键、CR等

二、基本正则表达式

1、grep

  用法  grep [Option] pattern file

    这其中的pattern,就是我们通过那些特殊涵义的字符组合出来的条件表达式

  常用选项

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

    -v,–invert-match,显示那些没有被匹配到的文本

    -c,–count,计算匹配到的行数

    -o,–only-match,只显示被匹配到的字段

    -n,–line-number,显示匹配到的行号

    -q,–quiet,静默模式,不输出匹配信息

    -e,实现多个选项之间的逻辑“或”的关系

    -A#,–after,显示匹配到的后#行

    -B#,–before,显示匹配到的前#行

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

    -E,egrep

注意:grep在数据中查找一个字符串时,是以整行为单位进行数据选取的,会把含有字符串的行显示出来,不含有字符串的行不会显示

2、基本正则表达式元字符

   (1)字符匹配

    .   匹配任意单个字符  

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

    [^]   匹配指定范围之外的任意单个字符

   (2)次数匹配

    *    匹配前面的字符任意次数,包括0次

    \?    匹配前面的字符0次或1次

    \+    匹配前面的字符至少一次

    .*    匹配任意字符任意次数

    \{m\}  匹配前面的字符m次

    \{m,n\} 匹配前面的字符[m,n]次

    \{m, \} 匹配前面的字符[m,+∞)次

    \{ ,n\} 匹配前面的字符[0,n]次

   (3)位置锚定:定位出现的位置

    ^    行首锚定,放在字符的前面,定位字符在行首位置

    $    行尾锚定,放在字符的后面,定位字符在行尾位置

    \<或\b 词首锚定,用在单词的最左侧

    \>或\b 词尾锚定,用在单词的左右侧

    ^$   匹配整行为空行

    ^pattern$   用于模式匹配整行

    \<pattern\>或者\bpattern\b   匹配整个单词

   (4)分组

    \(\)  将一个或多个字符捆绑在一起,当作一个整体进行处理,\(pattern\)\+

    分组括号中的模式匹配到的内容会被正则表达式引擎记录与内部的变量中,这些变量的命名方式为:\1,\2…

     \1  从左侧其,第一个左括号以及与之匹配右括号之间的模式所匹配到的字符

    后向引用:引用前面的分组括号中的模式所匹配字符(而非模式本身)

 

二、egrep及扩展正则表达式

    egrep=grep -E

  用法: egrep [options] pattern [file]…

扩展正则表达式的原字符

   (1)字符匹配

    .    匹配任意单个字符

    []    指定范围的单个字符

    [^]    指定范围之外的单个字符

   (2)次数匹配

    *    前面字符任意次数,包括0次

    ?    0次或1次

    +    至少1次,[1,+∞)

    {m}    匹配m次

    {m,n}   匹配[m,n]次

   (3)位置锚定

    ^    行首

    $    行尾

    \< ,\b  词首

    \> ,\b  词尾

   (4)分组  ()  ,后向引用  \1 ,\2…

   (5)或 逻辑组合  |

    a|b = a+b

    A|abc = A+abc

    (A|a)bc = Abc+abc

    

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

(0)
black_fishblack_fish
上一篇 2016-08-12 09:02
下一篇 2016-08-12 09:02

相关推荐

  • Shell脚本编程

    Shell脚本编程 关于脚本的调试     bash -n /path/to/some_script                   &…

    Linux干货 2016-08-15
  • keepalived高可用haproxy配合varnish实现wordpress的动静分离

    haproxy和nginx都可以作为七层和四层反代服务器对外提供服务,此文通过haproxy和keealived配置varnish搭建wordpress的动静分离站点 一、实验环境 五台虚拟机: haproxy-1:搭建haproxy和keepalived服务,ip地址:192.168.11.176 haproxy-2:搭建haproxy和keepalive…

    2017-07-03
  • quota AND raid

    1.磁盘配额 将home目录独立出来单独的分区,限制用户的使用。 (1)先创建分区,如下图的分区sda6 (2)命令同步系统的新增加分区:partx –a /dev/sda (3)命令格式化新分区:     (4)把创建的设备挂载到/mnt/home下    (5)迁移数据,移动之前要确保home分区没有使用。权限是保…

    Linux干货 2016-09-19
  • Homework Week-8 网络及脚本编程

    1、请描述网桥、集线器、二层交换机、三层交换机、路由器的功能、使用场景与区别。 设备 功能 使用场景 网桥 用于连接不同网段,将相似的网络连接起来,隔离信息。 连接不同部门间的局域网;连接地理位置分散并且相距较远的局域网,可以增加工作的物理距离;采用由网桥连接的多个局域网调节负载;网桥可以设置在局域网的关键部位,防止单点失常而破坏整个系统等。 集线器 对接收…

    Linux干货 2016-10-09
  • shll函数作业

    扫描/etc/passwd文件每一行,如发现GECOS字段为空,则填充用户名和单位电话为62985600,并提示该用户的GECOS信息修改成功。 [root@localhost sh.log]# cat whileGECOS.sh  #!/bin/bash #author:DYW #扫描/etc/passwd文件每一行…

    Linux干货 2016-08-24
  • yum详解

    yum YUM: Yellowdog Update Modifier,rpm的前端程序,用来解决软件包相关依赖性,可以在多个库之间定位软件包,up2date的替代工具 yum repository: yum repo,存储了众多rpm包,以及包的相关的元数据文件(放置于特定目录repodata下) yum对软件包的管理机制 —–引用了…

    Linux干货 2016-08-25