shell正则表达式

描述了一种字符串匹配的模式(pattern)。 

 在线匹配工具:

  1 http://www.regexpal.com/ 

      2 http://rubular.com/ 

     正则匹配软件

      McTracer 

      用过几个之后还是觉得这个是最好用的,支持将正则导成对应的语言如java C# js等还帮你转义了,Copy直接用就行了很方便,另外支持把正则表达式用法解释,如哪一段是捕获分组,哪段是贪婪匹配等等,总之用起来 So Happy .


 元字符介绍1-元字符

 "^" :^会匹配行或者字符串的起始位置,有时还会匹配整个文档的起始位置。 

   "$"  :$会匹配行或字符串的结尾

"\b" :不会消耗任何字符只匹配一个位置,常用于匹配单词边界 如 我想从字符串中"This is Regex"匹配单独的单词 "is" 正则就要写成 "\bis\b"  

    \b 不会匹配is 两边的字符,但它会识别is 两边是否为单词的边界 

 "\d": 匹配数字,

    例如要匹配一个固定格式的电话号码以0开头前4位后7位,如0737-5686123  正则:^0\d\d\d-\d\d\d\d\d\d\d$ 这里只是为了介绍"\d"字符,实际上有更好的写法会在     下面介绍。

 "\w":匹配字母,数字,下划线.

    例如我要匹配"a2345BCD__TTz" 正则:"\w+"  这里的"+"字符为一个量词指重复的次数,稍后会详细介绍。

 "\s":匹配空格 

    例如字符 "a b c" 正则:"\w\s\w\s\w"  一个字符后跟一个空格,如有字符间有多个空格直接把"\s" 写成 "\s+" 让空格重复

  ".":匹配除了换行符以外的任何字符

    这个算是"\w"的加强版了"\w"不能匹配 空格 如果把字符串加上空格用"\w"就受限了,看下用 "."是如何匹配字符"a23 4 5 B C D__TTz"  正则:".+"

  "[abc]": 字符组  匹配包含括号内元素的字符 

        这个比较简单了只匹配括号内存在的字符,还可以写成[a-z]匹配a至z的所以字母就等于可以用来控制只能输入英文了,


 元字符介绍-2-元字符的反义

几种反义

  写法很简单改成大写就行了,意思与原来的相反,这里就不举例子了

   "\W"   匹配任意不是字母,数字,下划线 的字符

   "\S"   匹配任意不是空白符的字符

 "\D"  匹配任意非数字的字符

   "\B"  匹配不是单词开头或结束的位置

   "[^abc]"  匹配除了abc以外的任意字符


 元字符介绍-3-量词

量词

 "*"(贪婪)   重复前面的模式  零次或更多

 "+"(懒惰)   重复前面的模式  一次或更多次

"?"(占有)   重复前面的模式  零次或一次

"{n}"  重复n次

"{n,m}"  重复n到m次

 "{n,}"  重复n次或更多次

量词的量词-me,懒惰限定符

 "*?"   重复任意次,但尽可能少重复 

      如 "acbacb"  正则  "a.*?b" 只会取到第一个"acb" 原本可以全部取到但加了限定符后,只会匹配尽可能少的字符 ,而"acbacb"最少字符的结果就是"acb" 

  "+?"  重复1次或更多次,但尽可能少重复

     与上面一样,只是至少要重复1次

  "??"  重复0次或1次,但尽可能少重复

      如 "aaacb" 正则 "a.??b" 只会取到最后的三个字符"acb"

  "{n,m}?"  重复n到m次,但尽可能少重复

          如 "aaaaaaaa"  正则 "a{0,m}" 因为最少是0次所以取到结果为空

  "{n,}?"    重复n次以上,但尽可能少重复

          如 "aaaaaaa"  正则 "a{1,}" 最少是1次所以取到结果为 "a"


捕获分组:

(exp),叫捕获分组,可以对捕获分组进行后向引用,后向引用:如果后而有相同的内容则可以直接引用前面定义的捕获组,以简化表达式,

先了解在正则中捕获分组的概念,其实就是一个括号内的内容 如 "(\d)\d" 而"(\d)" 这就是一个捕获分组,可以对捕获分组进行 后向引用 (如果后而有相同的内容则可以直接引用前面定义的捕获组,以简化表达式) 如(\d)\d\1 这里的"\1"就是对"(\d)"的后向引用

那捕获分组有什么用呢看个例子就知道了

如  "zery zery" 正则 \b(\w+)\b\s\1\b 所以这里的"\1"所捕获到的字符也是 与(\w+)一样的"zery",为了让组名更有意义,组名是可以自定义名字的

"\b(?\w+)\b\s\k\b" 用"?"就可以自定义组名了而要后向引用组时要记得写成 "\k";自定义组名后,捕获组中匹配到的值就会保存在定义的组名里

下面列出捕获分组常有的用法

 

"(exp)"    匹配exp,并捕获文本到自动命名的组里

"(?exp)"   匹配exp,并捕获文本到名称为name的组里

"(?:exp)"  匹配exp,不捕获匹配的文本,也不给此分组分配组号

以下为零宽断言

"(?=exp)"  匹配exp前面的位置

  如 "How are you doing" 正则"(?.+(?=ing))" 这里取ing前所有的字符,并定义了一个捕获分组名字为 "txt" 而"txt"这个组里的值为"How are you do";

"(?<=exp)"  匹配exp后面的位置

  如 "How are you doing" 正则"(?(?<=How).+)" 这里取"How"之后所有的字符,并定义了一个捕获分组名字为 "txt" 而"txt"这个组里的值为" are you doing";

"(?!exp)"  匹配后面跟的不是exp的位置

  如 "123abc" 正则 "\d{3}(?!\d)"匹配3位数字后非数字的结果

"(?  匹配前面不是exp的位置

  如 "abc123 " 正则 "(?

位置限定

^

行/字符串/文档的起始位置

$

 

 

元字符

\b

边界符,占位符

 

\B

匹配不是单词开头或结束的位置

 

\d

数字

0-9

\D

任意非数字的字符

 

\w

字母数字下划线

0-9 a-z A-Z _  word

\W

非数字字母下划线的字符

 

\s

空格

space

\S

任意不是空白字符的字符

 

.

除了换行符之外的任意字符

 

*

任意字符

 

[abc]

字符组

>=1且无序

[^abc]

 

 

量词

0-1

匹配前面的0或者1次

+

>=1

 

*

>=0

 

{n}

n

 

{n,m}

n-m

 

{n,}

>=n

 

懒惰限定符

*?

重复任意次,但尽可能少重复

 

+?

重复1次或更多次,

但尽可能少重复

??

 

 

{n,m}?

 

 

{n,}?

 

 

捕获分组

(exp)

匹配exp,并捕获文本到自动命名的组里

(?exp)

匹配exp,并捕获文本到名称为name的组里

(?:exp)

匹配exp,不捕获匹配的文本,也不给此分组分配组号

(?=exp)

匹配exp前面的位置

 

(?<=exp)

匹配exp后面的位置

 

(?!exp)

匹配后面跟的不是exp的位置

 

(?

匹配前面不是exp的位置

 

shell正则表达式_第1张图片

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

你可能感兴趣的:(工具篇-正则表达式,语言篇-shell编程)