正则表达式
前言
正则表达式一直都算是我的一个大坑.就好像常用的电话校验,这个一直都是在网上找回来的,也是惭愧.
趁着现在在做着系统学习,就去了解了下正则表达式.起码得看懂吧喂.....
介绍
正则表达式是一种特殊的字符串模式,用于匹配一组字符串,就好比用模具做产品,而正则就是这个模具,定义一种规则去匹配符合规则的字符。
常用的正则匹配工具
在线匹配工具 : 1 http://www.regexpal.com/ 2 http://rubular.com/
正则匹配软件 : McTracer
介绍(排名不分先后....)
Step one
"^":
介绍 ^会匹配行或者字符串的起始位置,有时还会匹配整个文档的起始位置,
例子 "^a\w\w"可以匹配到字符串"abc",而匹配不到"bac"
解释 因为 ^a \w \w 已经确保了第一位为"a",后两位就为任意的字母,数字或者下划线.
"$":
介绍 $会匹配行或字符串的结尾
例子 "\w\wc$"可以匹配到字符串"abc",而匹配不到"aba"
解释 因为 \w \w c$ 已经确保了最后一位为"c",前两位就为任意的字母,数字或者下划线.
"\b":记忆方法 - blank(这里有个详细介绍: 感觉很有用啊~~虽然我还没完全弄懂...http://blog.csdn.net/qq_33248299/article/details/53559924)
"\d":记忆方法 - digital
介绍 匹配数字
例子 "\d"可以匹配到字符串"1",而匹配不到"x"
解释 就是相当于1-9任意一个数字
"\w":
介绍 匹配字母,数字,下划线
例子 "\w"可以匹配到'x'
解释 字面意思....
"\s":记忆方法 - space
介绍 匹配空格
例子 ' '就这种
解释 字面意思....
"[abc]":
介绍 字符组 匹配包含括号内元素的字符
例子 "[abc]"可以匹配任意一个字母,就是'a','b','c'这三个都满足
解释 字面意思....
<在前面加个 ^ 就是反义..就是不匹配的,意思相反的>
Step two
"*" 重复零次或更多
例如"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次
Step three
"*?" 重复任意次,但尽可能少重复
如 "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"

浙公网安备 33010602011771号