正则表达式其实是一种特殊的公式,我们都知道,同一种问题可以使用不同的公式来解决,正如同一个字符串可以用不同的正则表达式解决一样,所以,正则表达式看起来很难懂,因为每个人写出来的表达式都是不一样的。 他们主要用来匹配一组字符串。
下面的表包含了字符串的完整列表以及它们在正则表达式上下文中的行为:
“^”:正则表达式的起始位置,有时还会匹配到整个文档的起始位置; “$”:正则表达式的结尾位置 “\b”:匹配字符的边界位置 “\d”:匹配数字 “\w”:匹配字母、数字、下划线 例如:“a2345BCD_TTz”的正则表达式:“\w+” “\s”:匹配空格 “.”:匹配除了换行符以外的任何字符 “[abc]”:字符组,匹配包含括号内元素的符号
“\W”:匹配任意不是字母、数字、下划线的字符 “\S”:匹配任意不是空格符的字符 “\D”:匹配任意 非数字的字符 “\B”:匹配不是单词开头或结束的位置 “[^abc]”:匹配除了abc以外的任意字符
“*”(贪婪) 重复零次或更多
例如”aaaaaaaa” 匹配字符串中所有的a 正则: “a*” 会出到所有的字符”a”
“+”(懒惰) 重复一次或更多次
例如”aaaaaaaa” 匹配字符串中所有的a 正则: “a+” 会取到字符中所有的a字符, “a+”与”a*”不同在于”+”至少是一次而”*” 可以是0次,稍后会与”?”字符结合来体现这种区别
“?”(占有) 重复零次或一次
例如”aaaaaaaa” 匹配字符串中的a 正则 : “a?” 只会匹配一次,也就是结果只是单个字符a
“{n}” 重复n次
例如从”aaaaaaaa” 匹配字符串的a 并重复3次 正则: “a{3}” 结果就是取到3个a字符 “aaa”;
“{n,m}” 重复n到m次
例如正则 “a{3,4}” 将a重复匹配3次或者4次 所以供匹配的字符可以是三个”aaa”也可以是四个”aaaa” 正则都可以匹配到
“{n,}” 重复n次或更多次 与{n,m}不同之处就在于匹配的次数将没有上限,但至少要重复n次 如 正则”a{3,}” a至少要重复3次
“*?” 重复任意次,但尽可能少重复
如 "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"匹配ip地址127.0.0.1:[0-9]{1,3}{.[0-9]{1,3}}{3}
