正则表达式入门

正则表达式入门

谈到正则表达式,我们就得先了解一下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 11:26
下一篇 2017-07-29 13:33

相关推荐

  • awk详解

    —————————— 课外练习 只处理用户ID为奇数的行,并打印用户名和ID号 [root@localhost ~]# awk -F: '{if($3%2!=0) {print&n…

    Linux干货 2016-09-25
  • 马哥教育网络班28期—第1、2天知识点概略

    没做随堂笔记,根据记忆手打,看看自己能记住多少。

    Linux干货 2017-12-03
  • lvs实践(lvs+nginx+mariadb+php—fpm+nfs搭建wordpress)

    lvs实践(lvs+nginx+mariadb+php—fpm+nfs搭建wordpress)   lvs实践(lvs+nginx+mariadb+php—fpm+nfs搭建wordpress) lvs_dr模型 nginx mariadb php-fpm wordpress   lvs实践(lvs+nginx+mariadb+php—f…

    2017-01-03
  • Linux软件包管理之rpm和yum的使用

    rpm命令的使用 什么是RPM? rpm:RPM Package Manager (原Redhat Package Manager) Linux 软件包管理工具 特定的程序由应用程序组成;     GPL:源码     glibs:标准的C库 常见Linux发行版的软件包管理器:…

    Linux干货 2016-08-25
  • 马哥教育网络班21期+第12周课程练习

    1、请描述一次完整的http请求处理过程; 建立或处理请求:接受请求或拒绝请求; 接收请求:接收来自于网络的请求报文中对某资源的一次请求的过程; 处理请求:对请求报文进行解析,并获取请求的资源及请求方法等相关信息; 访问资源:获取请求报文中请求的资源; 构建相应报文; 发送响应报文; 记录日志 2、httpd所支持的处理模型有哪些,他们分别适用于哪些环境。 …

    Linux干货 2016-10-24
  • shell脚本2——顺序选择语句

    流程控制      顺序执行      选择执行      循环执行 顺序执行:     条件选择:if语句 if语句为选择执行 注意:if语句可嵌套 单分支 if  判断条件:t…

    Linux干货 2016-08-18