正则基础详解

/^开头,结尾$/
* 匹配0次或多次
+ 匹配1-n次
?匹配0次或1次;  当?跟在 * + {n}  {n,m} {n,} 后面时,匹配模式是非贪婪的
{n} 匹配确定是n次,n非负数
.  匹配除了换行符\n以外的任何字符 包括点本身
(?:pattern) 小括号中的内容只匹配不捕获
(?=pattern) 正向预查
(?!pattern) 负向预查
x|y 匹配x或者y
[xyz] 匹配xyz中任何一个
[^xyz]匹配未包含xyz的任意字符
[a-z]匹配指定范围的字符
[^a-z]匹配不在a到z范围内的任意字符

\b 匹配一个单词的边界 /er\b/ 能匹配 never 中的er  不能匹配 verb 中的er
\B 匹配非单词边界

\d  任意一个数字
\D  任意一个非数字

\w 匹配包括下划线的任意字符  [a-zA-Z0-9]
\W 匹配任何非单词字符

\s 空白字符
\S 非空白字符

\n 匹配任意一个换行字符
\r 回车

reg.exec(str) 返回一个数组
[  0: 匹配到的大正则,  1: 匹配到的小分组1,  2: 小分组2,  3: 匹配到的第一个字符的索引,  4:input:整个str  ]

reg.test(str) 返回true/false


   // 1.反向引用  /(捕获的小分组)\数字/
    var reg=/(\w)(\w)\2\1/;// \2 第二个小分组匹配到的内容,\1 第一个小分组匹配到的内容
    var str="woow";
    console.log(reg.exec(str));// ["woow", "w", "o", index: 0, input: "woow"]
 //
 //  var reg = /(捕获的小分组)\数字/;  \数字 代表的是反向引用,表示 第几个括号内的子正则表达式所捕获的内容,如果小分组加了(?:=pattern),那么反向引用就不管用了。

    //2.小分组只匹配不捕获  (?:=pattern)
    var reg1=/^(?:b|c).+/;
    var str1="bbs.www.baidu.cn";
    console.log(reg1.exec(str1));//  小分组只匹配不捕获  (?:=pattern)
    //["bbs.www.baidu.cn", index: 0, input: "bbs.www.baidu.cn"]

    //3.正向预查(?=pattern) 要求匹配的时候满足括号中的条件
    //  反向预查 (?!pattern) 要求匹配的时候不满足括号中的条件
    //  小括号中的内容只匹配不捕获
    var reg3=/cai(?=8)/;
    var str3="cai9";
    var str4="cai8";
    console.log(reg3.exec(str3));// null
    console.log(reg3.exec(str4));// ["cai", index: 0, input: "cai8"]
    var reg4=/zhufeng(?!shanshang)/;
    var string="zhufengshanshang";
    var string1="zhufengshanshang";
    console.log(reg4.exec(string));// null
    console.log(reg4.exec(string1));//  ["zhufeng", index: 0, input: "zhufengshanshang"]


    //4. 匹配元字符 * +  ? .  就是它们本身就有特殊意义的,需要转义 \
    var reg5=/c\*/;
    var str05="c*";
    console.log(reg5.exec(str05));//["c*", index: 0, input: "c*"]

    //5.全局修饰符 ,g  不区分大小写 i ,行首行尾 m

    //6.[abc] a或b或c 中的任意一个
    //  [^] 所有的非空字符 不是空格, ^在/^/是以...开头的意思。在[^]是非的意思
    // [1-13] 从1到1或从1到3  不是1-13
    //[元字符] 表示元字符本身的意义,如 [.]表示点本身,不是 除了/n以外的任何字符

    //7. | 或者
    var reg06=/^(z|0).+/;
    var s="zhufeng";
    console.log(reg06.exec(s));// ["zhufeng", "z", index: 0, input: "zhufeng"]

    // 8.贪心匹配:在合法的情况下,正则会尽量多的去匹配字符,能匹配到4个,绝不会匹配3个
    //   非贪心匹配:?  如 {n,}?  *?  +?  {m,n}?

    //9.c{n} 匹配固定n个
    //  c{m,n} 匹配m到n个
    //  c{n,} 最少匹配n个,最多不限制

    //10.exec 与 全局修饰符g
    // 如果没加全局修饰符g,执行多少次都一样
    // 需要手动多次执行,每次执行都会进行新的匹配, 改变了正则的lastIndex的值
    var reg07=/(\w)(\w)(\w)/;
    var s1="bbs.baidu.cn";
    var result1=reg07.exec(s1);
    var result2=reg07.exec(s1);
    console.log(result1);// 如果没加全局修饰符g,执行多少次都一样
    console.log(result2);//["bbs", "b", "b", "s", index: 0, input: "bbs.baidu.cn"]

    var reg08=/(\w)(\w)(\w)/g;//需要手动多次执行 改变了正则的lastIndex的值
    var result3=reg08.exec(s1);
    var result4=reg08.exec(s1);
    console.log(result3);//["bbs", "b", "b", "s", index: 0, input: "bbs.baidu.cn"]
    console.log(result4);//["zhu", "z", "h", "u", index: 4, input: "bbs.baidu.cn"]

    //11.match 字符串类方法  str.match(reg)
    //设置了全局修饰符g,会自动进行多次匹配,并把匹配到的结果放入到数组中,注意没有index和input属性
    //match在没有分组的情况下能够更快捷的把多次匹配到的内容保存到数组中
    //exec正则类方法 reg.exec(str)  注意 二者写法完全不一样

    var reg09=/[bz]/;//不设置全局修饰符,结果和exec一样
    var s3="bbs.baidu.cn";
    console.log(s3.match(reg09));//["b", index: 0, input: "bbs.baidu.cn"]

    var regg=/[bz]/g;//设置了全局修饰符,会自动进行多次匹配,并把匹配到的结果放入到数组中,注意没有index和input属性
    var res=s3.match(regg);
    console.log(res);//["b", "b", "z"]
    //12.replace(参数1:正则表达式 被替换的内容,参数2:字符串/函数 用来替换第一个参数匹配到的内容)
    //字符串方法 查找并替换  ,返回值 一个新的字符串
    //如果reg中有全局标志g,那么将替换所有匹配到的子串,否则,它只替换第一个匹配子串
    //当第二个参数不是字符串,是函数的时候,每次匹配都调用该函数,将这个函数返回的字符串 作为替换文本使用,这个函数自定义替换规则
    //当第二参数是函数时,不仅自动执行此函数,还要给这个函数传3个参数
    //1.当正则没有分组时,传进去的第一个实参是正则捕获到的内容,第二个参数是捕获到的内容在原字符串中的索引位置,第三个参数是原字符串
    //2.当正则有分组的时候,第一个参数是大正则查找到的内容,后面依次是子正则查找到的内容
    //3.传完查找到的内容之后,再把总正则查找到的内容在原字符串中的索引传进,最后传入原字符串
    var ostring="XaZZcUdFe";
    var oreg=/[a-z]/g;
    ostring=ostring.replace(oreg,function () {
      return arguments[0]+"("+arguments[1]+")";
    });
    console.log(ostring);// Xa(1)ZZc(4)Ud(6)Fe(8)
    //不加()小分组,arguments:[ 0:匹配到的字符,1:查找到的内容在str中的索引,2:原字符串 ]
    var ostr="456a89b72cs";
    var oreg11=/(\d)(\d)/g;
    ostr=ostr.replace(oreg11,function () {
      return  Number(arguments[1])+Number(arguments[2]);
    });
    console.log(ostr);//96a17b9cs

    var astr="a1b2c3d4";
    var rr=/[a-z]/g;
    astr=astr.replace(rr,function (result,position,string) {
      return `在${position}的位置找到了${result},原字符串是${string};`;
    });
    console.log(astr);//在0的位置找到了a,原字符串是a1b2c3d4;
    // 在2的位置找到了b,原字符串是a1b2c3d4;2在4的位置找到了c,原字符串是a1b2c3d4;3在6的位置找到了d,原字符串是a1b2c3d4;4

str.search(reg)
str.split(reg,"")

未完待续。。。。


Maldivee
145 声望4 粉丝

如果你能看到我的梦想,请给我前行的力量,幸运是忠诚的祈祷,是光穿梭的暗道