Shell正则表达式

shell函数(使脚本看起来更加简洁)

传参就用$1

定义函数格式:

第一种格式:

fuction 定义的函数名 {

    命令

}

第二种格式:

定义的函数名() {

    命令

}

fuction ()可以省略,但二者必有其一。

引用函数直接输入函数名就可以引用。

fuction 定义的函数名 {

命令

return 2

}

正则表达式(匹配的时候加" ")

正则是做什么用的,就是匹配要符合你预期要求的字符串。

通配符与正则的区别

awk grep sed egrep使用的都是正则

find使用的都是通配符

最容易理解的区别:当你对文件名目录名使用字符时,使用的是通配符,当你对文件里的内容使用字符时,使用的是正则

基础正则

匹配任意单个字符(必须存在)

. 

比如l..e匹配到的是 like lone life

但不会匹配到 le ledoasdo lee 因为.代表单个,l..e有两个点,并且这两个字符必须存在,不能为空。

匹配开头

^ 

比如 ^ok匹配到的就是会以ok为开头的行,如果其他行有ok这两个字符,是在行首会被匹配到,不在一行之中的行首,哪怕是ok,也不会被匹配到。

匹配结尾

$ 

比如 ok$匹配到的就是会以ok为结尾的行,如果其他行有ok这两个字符,是在结尾会被匹配到,不在一行之中的结尾,哪怕是ok,也不会被匹配到。

匹配前一个字符的0个或多个

* 

比如 a*b 匹配到的就会是以b结尾的并且含有a的内容。*前面必须要有字符串。

匹配任意长度任意字符

.* 

比如.*b 匹配到的就会是以b结尾的任意内容,.*代表任意长度的字符串或字符。

匹配到[]里的所有字符,会把中括号里的所有字符以单个形式匹配出来

[] 

比如 [root] 匹配的是只要有r、o、o、t里的任意一个字符都可以匹配到。(跟通配符里的*一个作用)。

匹配取反,除了中括号里的内容都能匹配到

[^] 

比如 [^abc]匹配到的内容不会有a、b、c这三个字符,注意是三个字符包括三个字符组合成的字符串。

匹配取反的行首,就是把匹配到的字符,并且此字符是在行首,不显示。

^[^] 

比如^[^r] 匹配到的含有r这个字符,并且行首是以r开头的行不显示。

匹配花括号前面字符至少n个字符

n\{\}

比如o\{2\} 匹配到的就是含有o这个字符,并且最少含有2个o的内容。

匹配花括号前面字符至少n个字符,至多m个字符

\{n,m\}

比如 o\{1,3\} 匹配到的就是含有o这个字符,并且最少含有1个o,最多含有3个o的内容。

锚定单词首部

\<

比如\<root>\匹配到的内容就是 root,nloghiroot里的不会被匹配到,这种规定了你匹配的内容前后可以有特殊字符串,可以有空格,但不能是一长串单词中含有这个匹配的内容。

锚定单词尾部

\>

分组\1调用   ()\1 结合使用 调用店面的第一个分组

()

比如\(root\).*\1 匹配到的就是一行之中含有两个root。

拓展正则

要想支持拓展正则,必须使用

egrep或者grep –E

表示其前面字符至少出现一次情况

+ 

比如 #  + 匹配到的就是含有#和空格的内容,至于有多少空格无所谓,但至少有#  。

表示前面的字符出现最多一次的情况,可以是0个

?  

比如 a?b 匹配到的可以是ab、b、abbbbb、bbbb

表示匹配竖杠两旁的任意一个

| 

比如 cat|Cat 匹配到的是cat还有Cat

也可以 (c|C)at 匹配到的也是cat还有Cat,可以做分组,但不调用。
posted @ 2019-05-24 11:34  冷漠铁锤王富贵  阅读(796)  评论(0编辑  收藏  举报