1.1 正则表达式的概念以及演示
- 正则表达式可以用一些规定的字符来制定规则,并用来校验数据格式的合法性。
- 正则表达式就是用来验证各种字符串的规则。它内部描述了一些规则,我们可以验证用户输入的字符串是否匹配这个规则。正则表达式是一种强大的校验机制。
- 在Java中,我们经常需要验证一些字符串,例如:年龄必须是2位的数字、用户名必须是8位长度而且只能包含大小写字母、数字等。
package com.gch.d7_regex;
public class RegexDemo1 {
public static void main(String[] args) {
// 需求:校验qq号码,必须全部数字6-20位且不能以0开头
System.out.println(checkQQ("314314231432")); // true
System.out.println(checkQQ("null")); // false
System.out.println(checkQQ("2421")); // false
System.out.println(checkQQ("1354315a543")); // false
System.out.println("------------------------------");
// 正则表达式的初体验
System.out.println(checkQQ2("314314231432")); // true
System.out.println(checkQQ2("null")); // false
System.out.println(checkQQ2("2421")); // false
System.out.println(checkQQ2("1354315a543")); // false
String qq = "true";
System.out.println((qq != null && qq.matches("[1-9]\\d{5,19}")));
}
public static boolean checkQQ2(String qq){ // \\d表示数字
return qq != null && qq.matches("[1-9]\\d{5,19}");
}
public static boolean checkQQ(String qq){
// 核心思想:
// 先把异常数据进行过滤
// 下面的就是满足要求的数据了
// 1.判断qq号码的长度是否满足要求
if(qq == null || qq.length() < 6 || qq.length() > 20 || qq.startsWith("0")){
return false;
}
// 2.判断qq中是否全部是数字,不是返回false
for(int i = 0;i < qq.length();i++){
// 获取每位字符
char ch = qq.charAt(i);
// 判断这个字符是不是数字,不是数字直接返回false
// 说明还没到数字区域
if(ch < '0' || ch > '9'){
return false;
}
}
return true; // 肯定合法了
}
}
1.2 正则表达式的使用详解
package com.gch.d7_regex;
public class RegexDemo2 {
public static void main(String[] args) {
//public boolean matches(String regex):判断是否与正则表达式匹配,匹配返回true
// 正则表达式的一些常见匹配规则
// 只能是a b c 一个[]表示一个字符
System.out.println("-----------1-------------");
System.out.println("a".matches("[abc]")); // true
System.out.println("z".matches("[abc]")); // false
// 一个[]表示一个字符,第二个b没有什么东西跟它去匹配,所以不满足为false
System.out.println("ab".matches("[abc]")); // false
System.out.println("ab".matches("[abc][abc]")); // true
// 不能出现a b c , ^表示取反的意思
System.out.println("-----------2-------------");
System.out.println("a".matches("[^abc]")); // false
System.out.println("z".matches("[^abc]")); // true
System.out.println("zz".matches("[^abc]")); //false
System.out.println("zz".matches("[^abc][^abc]")); //true
// a到zA到Z(包括头尾的范围) , -写在[]里面表示范围的意思,写在[]外面表示就是一个-
System.out.println("-----------3-------------");
System.out.println("a".matches("[a-zA-Z]")); // true
System.out.println("z".matches("[a-zA-Z]")); // true
System.out.println("aa".matches("[a-zA-Z]"));//false
System.out.println("zz".matches("[a-zA-Z]")); //false
// 第一个z跟第一个[]去匹配 第二个z跟第二个[]去匹配
System.out.println("zz".matches("[a-zA-Z][a-zA-Z]")); //true
System.out.println("0".matches("[a-zA-Z]"));//false
System.out.println("0".matches("[a-zA-Z0-9]"));//true
System.out.println("0".matches("[0-9]"));//true
// [a-d[m-p]] a到d,或m到p
System.out.println("-----------4-------------");
System.out.println("a".matches("[a-d[m-p]]"));//true
System.out.println("d".matches("[a-d[m-p]]")); //true
System.out.println("m".matches("[a-d[m-p]]")); //true
System.out.println("p".matches("[a-d[m-p]]")); //true
System.out.println("e".matches("[a-d[m-p]]")); //false
System.out.println("0".matches("[a-d[m-p]]")); //false
// [a-z&&[def]] a-z和def的交集。为:d,e,f
// 细节:如果要求两个范围的交集,那么需要写符号&&
// 如果写成了一个&,那么此时&表示就不是交集了,而是一个简简单单的&符号,没有任何含义
System.out.println("----------5------------");
System.out.println("a".matches("[a-z&[def]]")); //true
System.out.println("&".matches("[a-z&[def]]")); //true
System.out.println("a".matches("[a-z&&[def]]")); //false
System.out.println("&".matches("[a-z&&[def]]")); //false
System.out.println("d".matches("[a-z&&[def]]")); //true
System.out.println("0".matches("[a-z&&[def]]")); //false
// [a-z&&[^bc]] a-z之间排除了b,c a-z和非bc的交集。(等同于[ad-z])
System.out.println("-----------6------------_");
System.out.println("a".matches("[a-z&&[^bc]]"));//true
System.out.println("b".matches("[a-z&&[^bc]]")); //false
System.out.println("0".matches("[a-z&&[^bc]]")); //false
// [a-z&&[^m-p]] a到z和除了m到p的交集。(等同于[a-lq-z])
System.out.println("-----------7-------------");
System.out.println("a".matches("[a-z&&[^m-p]]")); //true
System.out.println("m".matches("[a-z&&[^m-p]]")); //false
System.out.println("0".matches("[a-z&&[^m-p]]")); //false
}
}
package com.gch.d7_regex;
public class RegexDemo3 {
public static void main(String[] args) {
// 正则表达式的一些常见匹配规则
// \ 转义字符 改变后面那个字符原本的含义
//练习:以字符串的形式打印一个双引号
//双引号"在Java中表示字符串的开头或者结尾
//此时\表示转义字符,改变了后面那个双引号原本的含义
//把他变成了一个普普通通的双引号而已。
System.out.println("\""); // "
// \表示转义字符
// 这个\转义了后面的U 这个/转义了后面的m
// System.out.println("c:\Users\moon\IdeaProjects\\basic-code\\myapi\\src");
//两个\的理解方式:前面的\是一个转义字符,改变了后面\原本的含义,把他变成一个普普通通的\而已。
System.out.println("c:Users\\moon\\IdeaProjects\\basic-code\\myapi\\src\\com\\itheima\\a08regexdemo\\RegexDemo1.java");
//.表示任意一个字符 一个.只能表示一个字符
// 两个.表示前面需要有两个任意的字符
System.out.println("----------------1-----------------");
System.out.println("你".matches("..")); //false
System.out.println("你".matches(".")); //true
System.out.println("你a".matches(".."));//true
// \\d 表示任意的一个数字
// \\d只能是任意的一位数字
// 简单来记:在Java当中两个\表示一个\,因为一个\有特殊含义,表示转义字符
System.out.println("-----------------2----------------");
System.out.println("a".matches("\\d")); // false
System.out.println("3".matches("\\d")); // true
System.out.println("333".matches("\\d")); // false
System.out.println("333".matches("\\d\\d\\d")); // true
//\\w,小写w 只能是一位单词字符[a-zA-Z_0-9] 可以是字母、数字或者下划线
System.out.println("-----------------3----------------");
System.out.println("z".matches("\\w")); // true
System.out.println("2".matches("\\w")); // true
System.out.println("21".matches("\\w")); // false
System.out.println("你".matches("\\w"));//false
System.out.println("_".matches("\\w"));//true
// 非单词字符 大写W
System.out.println("----------------4---------------");
System.out.println("你".matches("\\W")); // true
// 以上正则匹配/表达式只能校验单个字符。
// 必须是数字 字母 下划线 至少 6位
System.out.println("-------------5---------------");
System.out.println("123213".matches("\\w{6,}"));
System.out.println("2442fsfsf".matches("\\w{6,}"));//true
System.out.println("244f".matches("\\w{6,}"));//false
// 必须是数字和字符 必须是4位
System.out.println("------------6-----------------");
System.out.println("shai".matches("[0-9a-zA-Z]{4}"));//true
System.out.println("23dF".matches("[a-zA-Z0-9]{4}"));//true
System.out.println("23 F".matches("[a-zA-Z0-9]{4}"));//false
System.out.println("adbc".matches("[\\w&&[^_]]{4}"));//true
System.out.println("23dF".matches("[\\w&&[^_]]{4}"));//true
System.out.println("23_F".matches("[\\w&&[^_]]{4}"));//false
}
}
1.3 正则表达式的常见案例
package com.gch.d7_regex;
public class RegexDemo4 {
public static void main(String[] args) {
/*
需求
请编写正则表达式验证用户输入的手机号码是否满足要求。请编写正则表达式验证用户输入的邮箱号是否满足要求。请编写正则表达式验证用户输入的电话号码是否满足要求。
验证手机号码 13112345678 13712345667 13945679027 139456790271
验证座机电话号码 020-2324242 02122442 027-42424 0712-3242434
验证邮箱号码 3232323@qq.com zhangsan@itcast.cnn dlei0009@163.com dlei0009@pci.com.cn
*/
//心得:
//拿着一个正确的数据,从左到右依次去写,一个一个的去看
//13112345678
//分成三部分:
//第一部分:1 表示手机号码只能以1开头
//第二部分:[3-9] 表示手机号码第二位只能是3-9之间的
//第三部分:\\d{9} 表示任意数字可以出现9次,也只能出现9次
System.out.println("----------------1------------------");
String regex1 = "1[3-9]\\d{9}";
System.out.println("13112345678".matches(regex1));//true
System.out.println("13712345667".matches(regex1));//true
System.out.println("13945679027".matches(regex1));//true
System.out.println("139456790271".matches(regex1));//false
//座机电话号码
//020-2324242 02122442 027-42424 0712-3242434
//思路:
//在书写座机号正则的时候需要把正确的数据分为三部分
//一:区号0\\d{2,3}
// 0:表示区号一定是以0开头的
// \\d{2,3}:表示区号从第二位开始可以是任意的数字,可以出现2到3次。
//二:- ?表示次数,0次或一次
//三:号码 号码的第一位也不能以0开头,从第二位开始可以是任意的数字,号码的总长度:5-10位
System.out.println("------------------2--------------------");
String regex2 = "0\\d{2,3}-?[1-9]\\d{4,9}";
System.out.println("020-2324242".matches(regex2)); // true
System.out.println("02122442".matches(regex2)); // true
System.out.println("027-42424".matches(regex2)); // true
System.out.println("0712-3242434".matches(regex2)); // true
//邮箱号码
//3232323@qq.com zhang_san@itcast.cnn dlei0009@163.com dlei0009@pci.com.cn
//思路:
//在书写邮箱号码正则的时候需要把正确的数据分为三部分
//第一部分:@的左边 \\w+ +表示一次或者多次,即至少出现一次
// \\w:a-z A-Z 0-9 _
// 表示任意的字母数字下划线,至少出现一次就可以了
//第二部分:@ 表示只能出现一次,也只能出现一次
//第三部分:
// [\\w&&[^_]]:表示任意的字符去掉下划线
// 3.1 .的左边[\\w&&[^_]]{2,6}
// 任意的字母加数字,总共出现2-6次(此时不能出现下划线)
// 3.2 . \\. 在Java当中两个\表示一个\
// 3.3 大写字母,小写字母都可以,只能出现2-3次[a-zA-Z]{2,3}
// 我们可以把3.2和3.3看成一组,这一组可以出现1次或者两次
System.out.println("----------------3------------------");
String regex3 = "\\w+@[\\w&&[^_]]{2,6}(\\.[a-zA-Z]{2,3}){1,2}";
System.out.println("3232323@qq.com".matches(regex3)); // true
System.out.println("zhangsan@itcast.cnn".matches(regex3)); // true
System.out.println("dlei0009@163.com".matches(regex3)); // true
System.out.println("dlei0009@pci.com.cn".matches(regex3)); // true
// 在实际开发中,很少会自己写正则表达式
// 百度一个类似的,自己改成公司要求的
String regex = "";
System.out.println("-----------------4----------------");
//24小时的正则表达式
String regex4 = "([01]\\d|2[0-3]):[0-5]\\d:[0-5]\\d";
System.out.println("23:11:11".matches(regex4));
String regex5 = "([01]\\d 2[0-3])(:[0-5]\\d){2}";
System.out.println("23:11:11".matches(regex5));
}
}
1.4 正则表达式在方法中的应用
package com.gch.d7_regex;
import java.util.Arrays;
/**
目标:正则表达式在方法中的使用
public String[] split(String regex):
-- 按照正则表达式匹配的内容进行分割字符串,返回一个字符串数组
public String replaceAll(String regex,String newStr)
-- 按照正则表达式匹配的内容进行替换
*/
public class RegexDemo6 {
public static void main(String[] args) {
String names = "小路dsahid123蓉儿3242asfda过儿";
String[] arrs = names.split("\\w+");
System.out.println(Arrays.toString(arrs));
for (int i = 0; i < arrs.length; i++) {
System.out.println(arrs[i]);
}
String names2 = names.replaceAll("\\w+" ," ");
System.out.println(names2);
}
}
1.5 正则表达式爬取信息
package com.gch.d7_regex;
import java.util.regex.Matcher;
import java.util.regex.Pattern;
/**
拓展:正则表达式爬取信息中的内容。(了解)
*/
public class RegexDemo7 {
public static void main(String[] args) {
String rs = "来黑马程序学习Java,电话020-43422424,或者联系邮箱" +
"itcast@itcast.cn,电话18762832633,0203232323" +
"邮箱bozai@itcast.cn,400-100-3233 ,4001003232";
// 需求:从上面的内容中爬取出 电话号码和邮箱。
// 1、定义爬取规则,字符串形式
String regex = "(\\w{1,30}@[a-zA-Z0-9]{2,20}(\\.[a-zA-Z0-9]{2,20}){1,2})|(1[3-9]\\d{9})" +
"|(0\\d{2,6}-?\\d{5,20})|(400-?\\d{3,9}-?\\d{3,9})";
// 2、把这个爬取规则编译成匹配对象。
Pattern pattern = Pattern.compile(regex);
// 3、得到一个内容匹配器对象
Matcher matcher = pattern.matcher(rs);
// 4、开始找了
while (matcher.find()) {
String rs1 = matcher.group();
System.out.println(rs1);
}
}
}
文章出处登录后可见!
已经登录?立即刷新