标签:
尽管开端现已说了正则操作分为四种,分别是匹配、更换、切开和获取,可是实质上都是匹配,如更换则是先匹配到待更换的内容,然后再将其更换掉;相同切开则是先匹配到用于切开的分隔符,然后再将其切开;获取则是匹配到的内容。
那么正派的根本匹配语法是哪些呢?String的比如现已说明了一些,如[],{}等。
正则表达式的四种操作,除了String类中的简便匹配、更换、切开、获取等操作外,真实的正则操作运用的是Pattern和Matcher,String的内部的一些操作也是运用的这两个类。他们的根本运用格局如下:
通常能够概括为以下过程:
用一个邮箱验证实例来演示一下匹配的操作,[a-zA-Z0-9_]表明接纳字母和数值还有下划线,后边跟一个+表明前面的字符规矩能够使一个或许一个以上,(\\.[a-zA-Z]+)+表明点加上字母,然后分为一组,这个组能够一个或许一个以上如.com.cn,详细代码如下:
先有两个问题,?2Fp>
3、切开
切开与获取的功用有必定的重合,获取是获取契合匹配的,而切开则是获取契合匹配以外的内容,通常切开都是运用直接运用String的split(regex)办法,如依照多个空格切开,代码如下:
4、获取
从一个文本文件读取内容,然后从中获取邮箱,也能够将其成为从网络页面上获取邮箱的功用,假如同一个邮箱的页面爬虫相同,示例代码如下:
附录
下面列出了一些正则中的特别字符或许规矩。
| 字符 | |
| x | 字符 x |
| \ | 反斜线字符 |
| \0n | 带有八进制值 0 的字符 n (0 <= n <= 7) |
| \0nn | 带有八进制值 0 的字符 nn (0 <= n <= 7) |
| \0mnn | 带有八进制值 0 的字符 mnn(0 <= m <= 3、0 <= n <= 7) |
| \xhh | 带有十六进制值 0x 的字符 hh |
| \uhhhh | 带有十六进制值 0x 的字符 hhhh |
| \t | 制表符 (‘\u0009’) |
| \n | 新行(换行)符 (‘\u000A’) |
| \r | 回车符 (‘\u000D’) |
| \f | 换页符 (‘\u000C’) |
| \a | 报警 (bell) 符 (‘\u0007’) |
| \e | 转义符 (‘\u001B’) |
| \cx | 对应于 x 的控制符 |
.
| 字符类 | |
| [abc] | a、b 或 c(简略类) |
| [^abc] | 任何字符,除了 a、b 或 c(否定) |
| [a-zA-Z] | a 到 z 或 A 到 Z,两端的字母包含在内(规模) |
| [a-d[m-p]] | a 到 d 或 m 到 p:[a-dm-p](并集) |
| [a-z&&[def]] | d、e 或 f(交集) |
| [a-z&&[^bc]] | a 到 z,除了 b 和 c:[ad-z](减去) |
| [a-z&&[^m-p]] | a 到 z,而非 m 到 p:[a-lq-z](减去) |
.
| 预界说字符类 | |
| . | 任何字符(与行完毕符可能匹配也可能不匹配) |
| \d | 数字:[0-9] |
| \D | 非数字: [^0-9] |
| \s | 空白字符:[ \t\n\x0B\f\r] |
| \S | 非空白字符:[^\s] |
| \w | 单词字符:[a-zA-Z_0-9] |
| \W | 非单词字符:[^\w] |
.
| POSIX 字符类(仅 US-ASCII) | |
| \p{Lower} | 小写字母字符:[a-z] |
| \p{Upper} | 大写字母字符:[A-Z] |
| \p{ASCII} | 一切 ASCII:[\x00-\x7F] |
| \p{Alpha} | 字母字符:[\p{Lower}\p{Upper}] |
| \p{Digit} | 十进制数字:[0-9] |
| \p{Alnum} | 字母数字字符:[\p{Alpha}\p{Digit}] |
| \p{Punct} | 标点符号:!”#$%&’()*+,-./:;<=>?@[]^_`{ |
| \p{Graph} | 可见字符:[\p{Alnum}\p{Punct}] |
| \p{Print} | 可打印字符:[\p{Graph}\x20] |
| \p{Blank} | 空格或制表符:[ \t] |
| \p{Cntrl} | 控制字符:[\x00-\x1F\x7F] |
| \p{XDigit} | 十六进制数字:[0-9a-fA-F] |
| \p{Space} | 空白字符:[ \t\n\x0B\f\r] |
.
| java.lang.Character 类(简略的 java 字符类型) |
| \p{javaLowerCase} |
| \p{javaUpperCase} |
| \p{javaWhitespace} |
| \p{javaMirrored} |
.
| Unicode 块和种类的类 | |
| \p{InGreek} | Greek 块(简略块)中的字符 |
| \p{Lu} | 大写字母(简略种类) |
| \p{Sc} | 钱银符号 |
| \P{InGreek} | 一切字符,Greek 块中的在外(否定) |
| [\p{L}&&[^\p{Lu}]] | 一切字母,大写字母在外(减去) |
.
| 鸿沟匹配器 | |
| ^ | 行的最初 |
| $ | 行的完毕 |
| \b | 单词鸿沟 |
| \B | 非单词鸿沟 |
| \A | 输入的最初 |
| \G | 上一个匹配的完毕 |
| \Z | 输入的完毕,仅用于最终的完毕符(假如有的话) |
| \z | 输入的完毕 |
.
| Greedy 数量词 | |
| X? | X,一次或一次也没有 |
| X* | X,零次或屡次 |
| X+ | X,一次或屡次 |
| X{n} | X,刚好 n 次 |
| X{n,} | X,最少 n 次 |
| X{n,m} | X,最少 n 次,可是不超越 m 次 |
.
| Reluctant 数量词 | |
| X?? | X,一次或一次也没有 |
| X*? | X,零次或屡次 |
| X+? | X,一次或屡次 |
| X{n}? | X,刚好 n 次 |
| X{n,}? | X,最少 n 次 |
| X{n,m}? | X,最少 n 次,可是不超越 m 次 |
.
| Possessive 数量词 | |
| X?+ | X,一次或一次也没有 |
| X*+ | X,零次或屡次 |
| X++ | X,一次或屡次 |
| X{n}+ | X,刚好 n 次 |
| X{n,}+ | X,最少 n 次 |
| X{n,m}+ | X,最少 n 次,可是不超越 m 次 |
.
| Logical 运算符 | |
| XY | X 后跟 Y |
| X | Y |
| (X) | X,作为捕获组 |
.
| Back 引证 | |
| \n | 任何匹配的 nth 捕获组 |
| 特别结构(非捕获) | |
| (?:X) | X,作为非捕获组 |
| (?idmsux-idmsux) | Nothing,可是将匹配象征i d m s u x on - off |
| (?idmsux-idmsux:X) | X,作为带有给定象征 i d m s u x on - off 的非捕获组 (?=X) X,经过零宽度的正 lookahead |
| (?!X) | X,经过零宽度的负 lookahead |
| (?<=X) | X,经过零宽度的正 lookbehind |
| (? | X,经过零宽度的负 lookbehind |
| (?>X) | X,作为独立的非捕获组 |
标签:
原文地址:http://www.cnblogs.com/wufanxin/p/4439314.html