zoukankan      html  css  js  c++  java
  • 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,可以做分组,但不调用。
  • 相关阅读:
    nginx设置缓存策略
    http缓存原理理解
    promise教程
    vue项目发布到github演示
    vue路由嵌套子路由不渲染
    hihocoder 1403 1407 1415 后缀数组*3 最长公共子串/最长不重叠重复出现的子串/最长k次重复子串
    hdu 4691 后缀数组+rmq 求子串lcp
    hdu1506+ luogu 1440 单调栈/单调队列裸题
    codeforces 873F 后缀数组+单调栈(fastio)
    HihoCoder
  • 原文地址:https://www.cnblogs.com/shuaiyin/p/10917135.html
Copyright © 2011-2022 走看看