参考网址:http://deerchao.net/tutorials/regex/regex.htm
简单元字符:
1.最简单的正则:假设你在一篇英文小说里查找hi,你可以使用正则表达式hi。(可以匹配hi,HI,Hi,hI这四种情况中的任意一种)
2.单词里包含hi这两个连续的字符,比如him,history,high等等。如果要精确地查找hi这个单词的话,我们应该使用\bhi\b,不要hi
3.虽然通常英文的单词是由空格,标点符号或者换行来分隔的,但是\b并不匹配这些单词分隔字符中的任何一个,它只匹配一个位置。
4.假如你要找的是hi后面不远处跟着一个Lucy,你应该用\bhi\b.\bLucy\b。(.是另一个元字符,匹配除了换行符以外的任意字符,同样是元字符,不过它代表的不是字符,也不是位置,而是数量——它指定*前边的内容可以连续重复使用任意次以使整个表达式得到匹配)
5.以0开头,然后是两个数字,然后是一个连字号“-”,最后是8个数字----->>0\d{2}-\d{8}(这里的\d是个新的元字符,匹配一位数字(0,或1,或2,或……)
常用的元字符
| 常用的元字符 | 说明 | |
| ------------- |:-------------:||
| . | 匹配除换行符以外的任意字符 | |
| \w | 匹配字母或数字或下划线或汉字 | |
| \s |匹配任意的空白符 | |
| \d | 匹配数字 | |
| \b | 匹配单词的开始或结束 | |
| ^ | 匹配字符串的开始t | |
| $ | 匹配字符串的结束 | |
特殊字符转义
如果你想查找元字符本身的话,比如你查找.,或者*,就出现了问题:你没办法指定它们,因为它们会被解释成别的意思。这时你就得使用\来取消这些字符的特殊意义。因此,你应该使用.和*。当然,要查找\本身,你也得用\
例如:deerchao.net匹配deerchao.net,C:\Windows匹配C:\Windows。
常用的限定符
| 常用的限定符 | 说明 | |
| ------------- |:-------------:||
| * | 重复零次或更多次 | |
| + | 重复一次或更多次 | |
| ? | 重复零次或一次 | |
| {n} | 重复n次 | |
| {n,}| 重复n次或更多次 | |
| {n,m} | 重复n到m次 | |