正则表达式入门

正则表达式入门

谈到正则表达式,我们就得先了解一下POSIX。POSIX的全称是Portable Operating System Interface for
uniX
,它由一系列规范构成,定义了UNIX,linux操作系统应当支持的功能,它定义了BREBasic Regular Expression,基本型正则表达式)和EREExtended Regular Express,扩展型正则表达式)两大流派。

正则表达式由只代表自身的字面值和代表特定含义的元字符组成,除非特别说明,正则表达式严格区分大小写。正则表达式的大致匹配过程是:

1.依次拿出表达式和文本中的字符比较,

2.如果每一个字符都能匹配,则匹配成功;一旦有匹配不成功的字符则匹配失败。

3.如果表达式中有量词或边界,遵循量词或边界指定的规则来匹配。

正则表达式入门

基础正则表达式中,如果你想使用? + () {},因为他们表示特殊含义,所以你需要将他们转义

而扩展正则表达式中,如果你想使用? + () {} ,就没必要加“\”了,进化版的正则表达式在这方面给我们提供了很大的便利正则表达式入门

所谓特殊含义,就是正则表达式中的含义。非特殊含义,就是这个符号本身。

+,*中大家会遇到贪婪模式的说法,也有称最长匹配原则,本质就是趋向于最大长度匹配。”.*”这个组合几乎可以匹配所有,贪婪性赤裸裸的暴露出来了。

基本正则表达式(BRE

字符匹配

(匹配的时候需要使用两个方括号,如[[ :alpha:]])
    .  表示任意单个字符,.会匹配除了换行符的任意字符
    [ ]   表示匹配范围内的任意单个字符
    [^ ]  表示匹配范围外的任意单个字符
    [:alpha:]   任意一个字母(相当于a-zA-Z)
    [:upper:]  任意一个大写字母(相当于A-Z)
    [:lower:]  任意一个小写字母(相当于a-z)
    [:digit:]   任意一个数字(相当于0-9)
    [:space:]  水平和垂直的空白字符(比blank包含的更多)
    [:blank:]   空白字符(空格和制表符)
    [:punct:]  标点符号
    [:alnum:]   任意字母和数字(相当于0-9a-zA-Z)
    [:print:]   可打印字符

匹配次数

    *   表示*号前面的一个字符的0-N次(它有一个贪婪模式,会尽量匹配最长)
    .*   表示任意多个长度的字符
    \?    表示\?符号前的字符0-1次
    \+     匹配\+前的字符至少1次
    \{m,n\}    表示\{m,n\}符号前的字符的m-n次
    \{m\}     表示{m\}符号前的字符m次
    \{n,\}     表示匹配前面字符至少n次
    \{,n}      表示匹配前面字符最多n次

位置锚定

    ^ 之后接字符    表示^ 之后的字符出现在行首
    $ 之前接字符    表示$之前的字符出现在行尾
    \> 表示\> 符号之后的字符出现在单词的尾部
    \< 表示\< 之前的字符出现在单词的首部
    \<字符 \>      表示只有小于号和大于号之间的字符

分组

    分组 : \(\) 将一个或多个字符捆绑在一起,当作一个整体进行处理,如 : \(root\)+
    后向引用 : 引用前面的分组括号中的模式所匹配字符,而非模式本身
 
    或者 : \|

拓展正则表达式(ERE

字符匹配

    .  表示任意单个字符,.会匹配除了换行符的任意字符
    []   匹配指定范围内的任意单个字符
    [^]  匹配指定范围外的任意单个字符
    [ :alnum : ]   字母和数字
    [ :alpha : ]   代表任何英文大小写字符,亦即 A-Z, a-z
    [ :lower : ]   小写字母
    [ :upper : ]   大写字母
    [ :blank : ]   空白字符(空格和制表符)
    [ :digit : ]   十进制数字
    [ :xdigit : ]  十六进制数字
    [ : graph :]   可打印的非空白字符
    [ :print :]   可打印字符
    [ :punct :]   标点符号

 

匹配次数

    * 匹配前面字符任意次,包括0次
    ? 0或1次
    +: 1次或多次
    {n}   匹配前面的字符n次
    {m,n} 匹配前面的字符至少m次,至多n次
    {,n}  匹配前面的字符至多n次
    {n,}  匹配前面的字符至少n次

位置锚定

    ^   行首锚定,用于模式的最左侧
 
    $   行尾锚定,用于模式的最右侧
 
    \< 或 \b     词首锚定,用于单词模式的左侧
 
    \> 或 \b     词尾锚定;用于单词模式的右侧
 
    \<PATTERN\> 匹配整个单词

分组

    ():分组,后面可以使用1 ,2 ,3...引用前面的分组
    a|b : a或b

优先级

优先级

符号

1

\

2

( )(?: )(?= )[ ]

3

*+?{n}{n,}{m,n}

4

^$

5

|

实战正则表达式入门

(思考的出发点不同,过程也就不尽相同,过程和结果同样重要

1找出/etc/rc.d/init.d/functions的基名(basename可以直接获取)。

正则表达式入门

2 找出/etc/rc.d/init.d/functions的目录名(dirname可以直接获取)。

正则表达式入门

3 统计last命令中以root用户登录的每个主机IP登录次数。

正则表达式入门

4 显示ifconfig命令中所有的IPV4地址。

正则表达式入门

5显示/etc/passwd中以/bin/bash结尾的行。

正则表达式入门

        基于最近的学习整理的资料,尚有诸多不足之处,还望大佬们多多指点!

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

(0)
LinuxWalkerLinuxWalker
上一篇 2017-07-29
下一篇 2017-07-29

相关推荐

  • LVM 逻辑卷管理器

    1、什么是LVM:PV、PE、VG、LV的意义    LVM:Logical Volume Manager(逻辑卷管理器),可以将多个物理分区整合成看起来像一个磁盘一样,并可随意增加或减少逻辑卷大小 dm:device mapper,将一个或多个底层块设备组织成一个逻辑设备的模块; /dev/mapper/VG_NAME-LV_NAME …

    Linux干货 2016-09-19
  • 第二周

    #第二周blog 作业 第二周blog 作业 1 目录管理命令:mkdir、rmdir mkdir命令 mkdir – make directories      mkdir [OPTION]… DIRECTORY…   &nbsp…

    Linux干货 2016-12-12
  • N25-Bazinga-第二周作业

    1.Linux文件管理类命令 命令 功能 命令 功能 pwd 显示当前目录 ls 显示目录下的内容 cd 改变所在目录 cat 显示文件的内容 grep 在文件中查找字符串 cp 复制文件 touch 创建文件 mv 移动文件 rm 删除文件 rmdir 删除目录 1.1 pwd命令 该命令的英文解释为print working&nbsp…

    Linux干货 2016-12-13
  • 为什么新建文件时,所在文件系统还有大量剩余空间,却提示此文件系统空间已满??

    一:答疑解惑:    这是因为该文件所在分区的inode号被用尽,虽然分区的剩余容量还有很多。 二:基本原理:   inode为何物block又为何物?以及,inode都有哪些特征?   ①我们知道,在linux文件系统中,文件名只是计算机用来给人看,而计算机本身只识别文件所对应的数字或编号,而这个编号或数字…

    2017-07-22
  • Linux进程篇16.3ps命令:进程管理工具

    ps命令:进程管理工具

    Linux干货 2017-12-18
  • Centos6系统救援模式

    CentOS 6系统救援模式 在学习了CentOS 5、6系统启动流程与启动故障排除之后,为了加深印象进行了如下破坏性尝试。 删除/boot目录与/etc/fstab文件后尝试修复系统 1. 首先是第一步删除/boot目录与/etc/fstab 删除/boot /etc/fstab 可以看到虽然boot目录无法删除但是目录中的文件已经全部删掉了。 2. 重新…

    Linux干货 2016-11-24