基本概念

  • 正则是匹配模式,要么匹配字符,要么匹配位置。

字符串匹配攻略

1.1横向模糊匹配

一个正则可匹配的字符串的长度不是固定的,可以是多种情况的。其实现的方式是使用量词。譬如{m,n},表示连续出现最少m次,最多n次。

  1. var regex = /ab{2,5}c/g;
  2. var string = "abc abbc abbbc abbbbc abbbbbc abbbbbbc";
  3. console.log( string.match(regex) );
  4. // => ["abbc", "abbbc", "abbbbc", "abbbbbc"]

注:g是一个修饰符,表示全局匹配,在目标字符串中按顺序找到满足匹配模式的所有子串,强调的是“所有”。

1.2纵向模糊匹配

一个正则匹配的字符串,具体到某一位字符时,它可以不是某个确定的字符,可以有多种可能。其实现的方式是使用字符组。譬如[abc],表示该字符是可以字符“a”、“b”、“c”中的任何一个。

  1. var regex = /a[123]b/g;
  2. var string = "a0b a1b a2b a3b a4b";
  3. console.log( string.match(regex) );
  4. // => ["a1b", "a2b", "a3b"]

1、js截取两个字符串之间的内容:

  1. var str = "aaabbbcccdddeeefff";
  2. str = str.match(/aaa(\S*)fff/)[1];
  3. alert(str);//结果bbbcccdddeee

2、js截取某个字符串前面的内容:

  1. var str = "aaabbbcccdddeeefff";
  2. tr = str.match(/(\S*)fff/)[1];
  3. alert(str);//结果aaabbbcccddd

3、js截取某个字符串后面的内容:

  1. var str = "aaabbbcccdddeeefff";
  2. str = str.match(/aaa(\S*)/)[1];
  3. alert(str);//结果 bbbcccdddeeefff

exec() 语法:RegExpObject.exec(string)

检索字符串中指定的值。返回找到的值,并确定其位置。

  1. var str="Hello world!";
  2. var patt=/Hello/g;
  3. var result=patt.exec(str);
  4. //["Hello", index: 0, input: "Hello world!", groups: undefined]

test 语法:RegExpObject.test(string)

用于检测一个字符串是否匹配某个模式.

  1. var patt=/Hello/g;
  2. var result=patt.test(str);
  3. document.write("返回值: " + result); // true

replace 语法:string.replace(searchvalue,newvalue)

  1. var str="Mr Blue has a blue house and a blue car";
  2. var n=str.replace(/blue/g,"red");
  3. //Mr Blue has a red house and a red car

search 语法:string.search(searchvalue)

用于检索字符串中指定的子字符串,或检索与正则表达式相匹配的子字符串。

  1. var str="Mr. Blue has a blue house";
  2. document.write(str.search("blue"));
  3. //15

match 语法:string.match(regexp)

可在字符串内检索指定的值,或找到一个或多个正则表达式的匹配。

  1. var str="The rain in SPAIN stays mainly in the plain";
  2. var n=str.match(/ain/gi);
  3. // ["ain", "AIN", "ain", "ain"]

修饰符

修饰符 描述
i 执行对大小写不敏感的匹配。
g 执行全局匹配(查找所有匹配而非在找到第一个匹配后停止)。
m 执行多行匹配。

方括号

表达式 描述
[abc] 查找方括号之间的任何字符。
[^abc] 查找任何不在方括号之间的字符。
[0-9] 查找任何从 0 至 9 的数字。
[a-z] 查找任何从小写 a 到小写 z 的字符。
[A-Z] 查找任何从大写 A 到大写 Z 的字符。
[A-z] 查找任何从大写 A 到小写 z 的字符。
[adgk] 查找给定集合内的任何字符。
[^adgk] 查找给定集合外的任何字符。
(red|blue|green) 查找任何指定的选项。

常用元字符

元字符 描述
. 查找单个字符,除了换行和行结束符。
\w 查找单词字符。
\W 查找非单词字符。
\d 查找数字。
\D 查找非数字字符。
\s 查找空白字符。
\S 查找非空白字符。
\b 匹配单词边界。
\B 匹配非单词边界。
\0 查找 NULL 字符。
\n 查找换行符。

量词

量词 描述
n+ 匹配任何包含至少一个 n 的字符串。例如,/a+/ 匹配 “candy” 中的 “a”,”caaaaaaandy” 中所有的 “a”。
n* 匹配任何包含零个或多个 n 的字符串。例如,/bo*/ 匹配 “A ghost booooed” 中的 “boooo”,”A bird warbled” 中的 “b”,但是不匹配 “A goat grunted”。
n? 匹配任何包含零个或一个 n 的字符串。例如,/e?le?/ 匹配 “angel” 中的 “el”,”angle” 中的 “le”。
n{X} 匹配包含 X 个 n 的序列的字符串。例如,/a{2}/ 不匹配 “candy,” 中的 “a”,但是匹配 “caandy,” 中的两个 “a”,且匹配 “caaandy.” 中的前两个 “a”。
n{X,} X 是一个正整数。前面的模式 n 连续出现至少 X 次时匹配。例如,/a{2,}/ 不匹配 “candy” 中的 “a”,但是匹配 “caandy” 和 “caaaaaaandy.” 中所有的 “a”。
n{X,Y} X 和 Y 为正整数。前面的模式 n 连续出现至少 X 次,至多 Y 次时匹配。例如,/a{1,3}/ 不匹配 “cndy”,匹配 “candy,” 中的 “a”,”caandy,” 中的两个 “a”,匹配 “caaaaaaandy” 中的前面三个 “a”。注意,当匹配 “caaaaaaandy” 时,即使原始字符串拥有更多的 “a”,匹配项也是 “aaa”。
n$ 匹配任何结尾为 n 的字符串。
^n 匹配任何开头为 n 的字符串。
?=n 匹配任何其后紧接指定字符串 n 的字符串。
?!n 匹配任何其后没有紧接指定字符串 n 的字符串。