博客 |
---|
Java-常用API(初级) |
文章目录
无正则案例演示
再写正则表达式之前做一个检查qq的案例,为什么要正则表达式?
校验qq号码.
1:要求必须是5-15位数字
2:0不能开头
分析:
A:键盘录入一个QQ号码
B:写一个功能实现校验
C:调用功能,输出结果。
代码演示
public class LoginDemo {
public static void main(String[] args) {
Scanner sc = new Scanner(System.in);
String s = sc.nextLine();
boolean bool = checkQQ(s);
System.out.println(bool);
}
public static boolean checkQQ(String qq){
boolean flag =true;
//首先判断该qq是否是0开头q
if(!qq.startsWith("0")){
//在判断长度是否是在6-10之间
if(qq.length()>=6&&qq.length()<=10){
//判断是否全部是数字
char[] chars = qq.toCharArray();
for (int x = 0; x <chars.length ; x++) {
//判断是否是数字
if(!Character.isDigit(chars[x])){
flag = false;
break;
}
}
}else{
flag = false;
}
}else{
flag = false;
}
return flag;
}
}
正则表达式
举几个常用的正则表达式。
A:字符
x 字符 x。举例:'a'表示字符a
\\ 反斜线字符。
\n 新行(换行)符 ('\u000A')
\r 回车符 ('\u000D')
B:字符类
[abc] a、b 或 c(简单类)
[^abc] 任何字符,除了 a、b 或 c(否定)
[a-zA-Z] a到 z 或 A到 Z,两头的字母包括在内(范围)
[0-9] 0到9的字符都包括
C:预定义字符类
. 任何字符。我的就是.字符本身,怎么表示呢? \.
\d 数字:[0-9]
\w 单词字符:[a-zA-Z_0-9]
在正则表达式里面组成单词的东西必须有这些东西组成
D:边界匹配器
^ 行的开头
$ 行的结尾
\b 单词边界
就是不是单词字符的地方。
举例:hello world?haha;xixi
E:Greedy 数量词
X? X,一次或一次也没有
X* X,零次或多次
X+ X,一次或多次
X{n} X,恰好 n 次
X{n,} X,至少 n 次
X{n,m} X,至少 n 次,但是不超过 m 次
正则表达式:符合一定规则的字符串。
校验一个qq就需要判断那么多的条件,引入正则表达式就可以解决该问题
String类中一个匹配正则表达式方法:
public boolean matches(String regex)告知此字符串是否匹配给定的正则表达式
正则表示式校验qq代码演示
[1-9][0-9]{5,11}等价于[1-9]\\d{5,11}
[1-9]如果后面没有数量词默认是一位
[0-9]==\d需要使用\来转译也就是\\d
{5,11}是[0-9]的数量词,表示至少的5位数,但不超过11位数
public class LoginDemo {
public static void main(String[] args) {
Scanner sc = new Scanner(System.in);
String s = sc.nextLine();
boolean bool = checkQQ2(s);
System.out.println(bool);
}
public static boolean checkQQ2(String qq){
//String regex= "[0-9][1-9]{5,11}";
//boolean bool = qq.matches(regex);
//return qq.matches("[1-9][1-9]{5,11}");
return qq.matches("[1-9]\\d{5,11}");
}
}
正则表示的应用
String类的public boolean matches(String regex):判断是否符合正则表达式
String类的public String[] split(String regex):分割功能
String类的public String replaceAll(String regex,String replacement):正则表达式替换功能
正则表达式获取功能
Pattern和Matcher类的使用
String类的public boolean matches(String regex):判断是否符合正则表达式
需求1:判断手机号码是否满足要求?
分析:
A:键盘录入手机号码
B:定义手机号码的规则
13436975980
13688886868
13866668888
13456789012
13123456789
18912345678
18886867878
18638833883
C:调用功能,判断即可
D:输出结果
1[38]\\d{9}
1第一位只能是1
[38]只能是3或者8没有数量词占1位
\\d==[0-9]必须是9位数
代码演示
public class MatchesDemo {
public static void main(String[] args) {
//创建一个键盘录入对象
Scanner sc = new Scanner(System.in);
String s = sc.nextLine();
//创建正则表达式字符串
String regex = "1[38]\\d{9}";
boolean bool = s.matches(regex);
System.out.println(bool);
}
}
需求2:校验邮箱
分析:
A:键盘录入邮箱
B:定义邮箱的规则
1517806580@qq.com
liuyi@163.com
linqingxia@126.com
fengqingyang@sina.com.cn
fqy@itcast.cn
C:调用功能,判断即可
D:输出结果
代码演示
public class MatchesDemo2 {
public static void main(String[] args) {
//创建一个键盘录入对象
Scanner sc = new Scanner(System.in);
String s = sc.nextLine();
//fengqingyang@sina.com.cn 不满足的正则表达式
//String regex = "[a-zA-Z_0-9]+@[a-zA-Z_0-9]{2,6}\\.[a-zA-Z_0-9]{2,3}";
//fengqingyang@sina.com.cn 满足的正则表达式
String regex = "[a-zA-Z_0-9]+@[a-zA-Z_0-9]{2,6}(\\.[a-zA-Z_0-9]{2,3})+";
boolean bool = s.matches(regex);
System.out.println(bool);
}
}
String类的public String[] split(String regex):分割功能
根据给定正则表达式的匹配拆分此字符串。
举例:
百合网,世纪佳缘,珍爱网,QQ
搜索好友
性别:女
范围:“18-24”
代码演示
*/
public class RegexDemo {
public static void main(String[] args) {
//定义一个年龄搜索范围
String ages = "18-24";
//定义规则
String regex = "-";
//调用方法
String[] strArray = ages.split(regex);
//遍历
//for(int x=0; x<strArray.length; x++){
//System.out.println(strArray[x]);
//}
//如何得到int类型的呢?
int startAge = Integer.parseInt(strArray[0]);
int endAge = Integer.parseInt(strArray[1]);
//键盘录入年龄
Scanner sc = new Scanner(System.in);
System.out.println("请输入你的年龄:");
int age = sc.nextInt();
if(age>=startAge && age<=endAge) {
System.out.println("你就是我想找的");
}else {
System.out.println("不符合我的要求,gun");
}
}
}
分割功能练习1
public class RegexDemo2 {
public static void main(String[] args) {
// 定义一个字符串
String s1 = "aa,bb,cc";
// 直接分割
String[] str1Array = s1.split(",");
for (int x = 0; x < str1Array.length; x++) {
System.out.println(str1Array[x]);
}
System.out.println("---------------------");
String s2 = "aa.bb.cc";
String[] str2Array = s2.split("\\.");
for (int x = 0; x < str2Array.length; x++) {
System.out.println(str2Array[x]);
}
System.out.println("---------------------");
String s3 = "aa bb cc";
String[] str3Array = s3.split(" +");
for (int x = 0; x < str3Array.length; x++) {
System.out.println(str3Array[x]);
}
System.out.println("---------------------");
//硬盘上的路径,我们应该用\\替代\
String s4 = "E:\\JavaSE\\day14\\avi";
String[] str4Array = s4.split("\\\\");
for (int x = 0; x < str4Array.length; x++) {
System.out.println(str4Array[x]);
}
System.out.println("---------------------");
}
}
分割功能练习2
请写代码实现最终输出结果是:“27 38 46 50 91”
分析:
A:定义一个字符串
B:把字符串进行分割,得到一个字符串数组
C:把字符串数组变换成int数组
D:对int数组排序
E:把排序后的int数组在组装成一个字符串
F:输出字符串
public class RegexTest {
public static void main(String[] args) {
// 定义一个字符串
String s = "91 27 46 38 50";
// 把字符串进行分割,得到一个字符串数组
String[] strArray = s.split(" ");
// 把字符串数组变换成int数组
int[] arr = new int[strArray.length];
for (int x = 0; x < arr.length; x++) {
arr[x] = Integer.parseInt(strArray[x]);
}
// 对int数组排序
Arrays.sort(arr);
// 把排序后的int数组在组装成一个字符串
StringBuilder sb = new StringBuilder();
for (int x = 0; x < arr.length; x++) {
sb.append(arr[x]).append(" ");
}
//转化为字符串
String result = sb.toString().trim();
//输出字符串
System.out.println("result:"+result);
}
}
String类的public String replaceAll(String regex,String replacement):正则表达式替换功能
使用给定的 replacement 替换此字符串所有匹配给定的正则表达式的子字符串。
代码演示
public class MatchesDemo {
public static void main(String[] args) {
String s = "helloqq12345worldkh622112345678java";
// 我要去除所有的数字,用*给替换掉
String regex1 = "\\d+";
String regex2 = "\\d";
String s1 = "*";
String s2 = s.replaceAll(regex1, s1);
String s3 = s.replaceAll(regex2, s1);
System.out.println("\\d+"+"----"+s2);// \\d+:表示出现数字一次或者一次以上替换为*
System.out.println("\\d"+"----"+s3);// \\d:表示只要是数字每一位都替换为*
System.out.println("--------------------------");
// 直接把数字干掉
String regex3 = "\\d+";
String s4 = "";
String s5 = s.replaceAll("\\d+", "");
System.out.println("\\d+"+"----"+s5); // \\d+:表示出现一次或者多次数字以上替换为空
}
}
结果:
\d+----helloqq*worldkh*java
\d----helloqq*****worldkh************java
--------------------------
\d+----helloqqworldkhjava
Pattern和Matcher类的使用:正则表达式获取功能
一定要注意这是正则表达式的获取功能,不是判断功能。判断功能还是使用String类中mather
模式和匹配器的基本使用顺序
代码演示
public class MatchesDemo {
public static void main(String[] args) {
//模式和匹配器的典型调用顺序
//把正则表达式编程模式对象
Pattern pattern = Pattern.compile("a*b");
//通过模式对象,获取到匹配器对象,这是时候需要传入被匹配的字符串
Matcher mather = pattern.matcher("aaaab");
//调用匹配器对象的功能
boolean bool = mather.matches();
System.out.println("bool-"+bool);//true
System.out.println("-----------------------------");
//这个是判断功能,但是如果做判断,这样做就有点麻烦了,我们直接用字符串的方法做
String s = "aaaaab";
String regex = "a*b";
boolean bool2 = s.matches(regex);
System.out.println("bool2-"+bool2);//true
}
}