看了热榜正则表达式都上榜了目前正则表达式榜一是Python的 经过这几天呕心沥血不眠不休 终于今天Java的正则表达式它来了 还有练习题 耗时9981个小时 都是干货 赶紧收藏起来!!!!
正则表达式:正确规则的表达式 通常用来检测字符串是否符合某规则、根据某规则切分字符串 或 替换符合规则的文本 例如: 检查校验字符串中的 QQ 号是否如何如下规则: ①必须为 5~15 位数字 ②不能以 0 开头 若使用之前代码:
以上要求就可以变成一个正则表达式:[1-9][0-9]{4,14} 通过正则表达式,我们就可以检查字符串中的 QQ 号是否符合要求了。
举例:校验手机号码 1:要求为 11 位数字 2:第 1 位为 1,第 2 位为 3、4、5、7、8 中的一个,后面 9 位为 0 到 9 之间的任意数字。 代码演示: String phone = "18810022666"; String regex = "1[34578][0-9]{9}"; boolean flag = phone.matches(regex);
方法名 | 描述 |
---|---|
boolean matches(String regex) | 当前字符串是否匹配给定的正则表达式 |
String replaceAll(String regex,String replacement) | 使用 replacement 替换当前字符串中所有符号正则表 达式的内容 |
String[] split(String regex) | 根据给定的正则表达式拆分当前字符串 |
练习: 1、
举例:校验 qq 号码. 1:要求必须是 5-15 位数字 2:0 不能开头 代码演示: String qq = "604154942"; String regex = "[1-9][0-9]{4,14}"; boolean flag2 = qq.matches(regex);
2、
举例:校验手机号码 1:要求为 11 位数字 2:第 1 位为 1,第 2 位为 3、4、5、7、8 中的一个,后面 9 位为 0 到 9 之间的任意数字。 代码演示: String phone = "18810022666"; String regex = "1[34578][0-9]{9}"; boolean flag = phone.matches(regex);
3、
举例:将字符串中的数字全部替换成!号 String str = "1a2b3c4d"; str = str.replaceAll("\\d", "!"); System.out.println(str);
4、
//根据空格切割字符串 String str = "我 很 帅"; String[] arr = str.split(" "); for(int i=0;i<arr.length;i++){ System.out.println(arr[i]); }
5、注意:.的正则写法必须为\\.
//根据.切割 IP 地址 String str = "192.168.11.88"; String[] arr = str.split("\\."); for(int i=0;i<arr.length;i++){ System.out.println(arr[i]); }
表达式 | 描述 |
---|---|
^[a-z0-9_-]{3,16}$ | 用户名 |
^[a-z0-9_-]{6,18}$ | 密码 |
^([a-z0-9_\.-]+)@([\da-z\.-]+)\.([a-z\.]{2,6})$ | 电子邮箱 |
[\u4e00-\u9fa5] | 匹配中文字符的正则表达式 |
练习: 1、从控制台输入一个字符串。使用正则来对字符串进行一系列操作: ①判断字符串是否是一个合格的用户名 ②将字符串中的数字用”#”号替代. 数字的正则:[0-9] 或者 \\d ③根据”#”号将字符串切割成字符串数组并遍历展示
参照帮助文档,在 Pattern 类中有正则表达式的的规则定义,正则表达式中明确区分大小写字母。我们 来学习语法规则。
规则:x 含义:代表的是字符 x 例如:匹配规则为 "a",那么需要匹配的字符串内容就是 ”a”
规则:\\\\ 含义:代表的是斜线字符'\\' 例如:匹配规则为"\\\\" ,那么需要匹配的字符串内容就是 ”\\”
规则:\\t 含义:制表符 例如:匹配规则为"\\t" ,那么对应的效果就是产生一个制表符的空间
规则:\\n 含义:换行符 例如:匹配规则为"\\n",那么对应的效果就是换行,光标在原有位置的下一行
规则:\\r 含义:回车符 例如:匹配规则为"\\r",那么对应的效果就是回车后的效果,光标来到下一行行首
规则:[abc] 含义:代表的是字符 a、b 或 c 例如:匹配规则为"[abc]",那么需要匹配的内容就是字符 a,或者字符 b,或字符 c 的一个
规则:[^abc] 含义:代表的是除了 a、b 或 c 以外的任何字符 例如:匹配规则为"[^abc]",那么需要匹配的内容就是不是字符 a,或者不是字符 b,或不是字符 c 的任意一个字符
规则:[a-zA-Z] 含义:代表的是 a 到 z 或 A 到 Z,两头的字母包括在内 例如:匹配规则为"[a-zA-Z]",那么需要匹配的是一个大写或者小写字母
规则:[0-9] 含义:代表的是 0 到 9 数字,两头的数字包括在内 例如:匹配规则为"[0-9]",那么需要匹配的是一个数字
规则:[a-zA-Z_0-9] 含义:代表的字母或者数字或者下划线(即单词字符) 例如:匹配规则为" [a-zA-Z_0-9] ",那么需要匹配的是一个字母或者是一个数字或一个下滑线
规则:. 含义:代表的是任何字符 例如:匹配规则为" . ",那么需要匹配的是一个任意字符。
规则:\\d 含义:相当于[0-9]。代表的是 0 到 9 数字,0 和 9 包括在内。 例如:匹配规则为"\\d ",那么需要匹配的是一个数字
规则:\\w 含义:相当于[a-zA-Z_0-9]。代表的字母或者数字或者下划线 例如:匹配规则为"\\w ",,那么需要匹配的是一个字母或者是一个数字或一个下滑线
边界匹配器:^ 含义:代表以某些内容开头
边界匹配器:$ 含义:代表以某些内容结尾
边界匹配器:\\b 含义:代表的是单词边界。 注意:不能单独使用,几乎不使用 例如:匹配规则为"\\b[abc]\\b",那么代表的是字母 a 或 b 或 c 的左右两边需要的是非单词字符 ([a-zA-Z_0-9])
String regex = "\\b[a]\\b"; String str = "a"; booleanflag = str.matches(regex);
数量词:X? 含义:代表的是 X 出现 0~1 次 例如:匹配规则为"a?",那么需要匹配的内容是一个字符 a,或者一个 a 都没有
数量词:X* 含义:代表的是 X 出现 次数≥0 例如:匹配规则为"a*",那么需要匹配的内容是多个字符 a,或者一个 a 都没有
数量词:X+ 含义:代表的是 X 出现 次数≥1 例如:匹配规则为"a+",那么需要匹配的内容是多个字符 a,或者一个 a
数量词:X{n} 含义:代表的是 X 出现 次数= n 例如:匹配规则为"a{3}",那么需要匹配的内容是 3 个字符 a
数量词:X{n,} 含义:代表的是 X 出现 至少 n 次 例如:匹配规则为"a{3, }",那么需要匹配的内容是最少有 3 个字符 a
数量词:X{n,m} 含义:代表的是 X 出现至少 n 次,但是不超过 m 次 例如:匹配规则为"a{5,8}",那么需要匹配的内容是有 5 个字符 a 到 8 个字符 a 之间
逻辑运算符:XY 含义:代表的是 X 后紧跟着 Y 例如:匹配规则为"ab",那么需要匹配的字符串内容就是 ”ab”
逻辑运算符:X|Y 含义:代表的是 X 或 Y 例如:匹配规则为"a|b",那么需要匹配的字符串内容就是 ”a”或”b”
逻辑运算符:(X) 含义:代表的是()括号内的数据作为一个整体出现 例如:匹配规则为"(hello)+",那么需要匹配的内容是组内数据要出现多次,如”hellohellohello”; 或者组内数据出现一次,如”hello”。