## 正则表达式
### 次数匹配
1. **+** : 一次或者者屡次
2. *:零次或者者屡次
3. ?:零次或者者一次
4. {n,m}:最少 n 次,最多 m 次
5. {n,}:最少n次
6. {,m}:最多m次
### 特殊匹配元素
主要是代表少量特性的元素
1. . :代表除了换行之外的任意字符,例如 `.*` 匹配任意多个字符
2. \d : 代表任何一个数字,例如匹配一个座机号:`0\d{2}-\d{7}`
3. \w : 匹配字母或者数字或者下划线,等价于 [A-Za-z0-9_],不能匹配汉字
4. \D:匹配任意非数字的字符
5. [ ] : 字符集合,范围匹配,
? + [0-9] 代表数字 0-9的任何一个数字
? + [abc] 代表字母 abc 中的一个字符
? + [a-z] 代表字母 abc...z 中的一个字符
? + [!?] 代表符号 !? 中的一个符号
? + [A-Za-z0-9] 可以把所有字符拼接起来供选择,中间不带空格
### 特殊字符
1. ^ :反义符号;也代表一个字符串的开始
? + [^abcd] : 除了abcd的字符
2. $: 代表一个字符串的结束
3. | : 分歧条件,相当于或者者, `\d{2}|\d{3}` 两个数字或者者三个数字
4. ( ) : 分组,把括号里的内容当做一个整体
5. \ : 转义,对特殊字符需要进行转义,例如匹配 sno*w, 需要正则 `sno\*w`
### 练习
1. 只包含(中文,大小写字符,数字)的字符串,长度为 1 到 8
? `^[\u4e00-\u9fa5a-zA-Z0-9]{1,8}$`
2. 获取 Url 中的参数, url = webApp/users/buyerOrders/orderInfo/1803271202gqo6a7tosn7e
? ```
? ? ? private static void test20() {
? ? ? ? ? System.out.println("------------test20()------------------");
? ? ? ? ? // 订单介绍
? ? ? ? ? String url = "webApp/users/buyerOrders/orderInfo/1803271202gqo6a7tosn7e";
? ? ? ? ? String pattern = "webApp/users/buyerOrders/orderInfo/(.*)";
? ? ? ? ? Pattern pt = Pattern.compile(pattern);
? ? ? ? ? Matcher matcher = pt.matcher(url);
? ? ? ? ? if (matcher.find()) {
? ? ? ? ? ? ? System.out.println("uri:" + matcher.group(1));
? ? ? ? ? }
? ? ? }
? ```