热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

时间日期的操作类和其他常用类

时间日期的操作类和其他常用类一、Calendar如何创建对象,有哪些常用方法?Calendar类的定义:例如:publicabstractclassCalendar他是一个抽象类,

时间日期的操作类和其他常用类

一、Calendar如何创建对象,有哪些常用方法?
Calendar类的定义:
例如:
public abstract class Calendar 他是一个抽象类,它不能通过new+构造方法的方式构建对象

构造方法:
1.protected Calendar() 构建具有默认时区和默认的 FORMAT语言环境的日历。
2.protected Calendar(TimeZone zone, Locale aLocale) 构造具有指定时区和区域设置的日历。

Calendar类的定义和它的protected修饰符修饰的构造方法,决定Calendar类的对象创建和特殊,不会是new+构造方法的方式
通过本类提供静态方法完成。
静态方法:
1.static Calendar getInstance() 使用默认时区和区域设置获取日历。

2.static Calendar getInstance(Locale aLocale) 使用默认时区和指定的区域设置获取日历。

3.static Calendar getInstance(TimeZone zone) 使用指定的时区和默认语言环境获取日历。

4.static Calendar getInstance(TimeZone zone, Locale aLocale) 获取具有指定时区和区域设置的日历。

创建Calendar类对象:
1.例如:Calendar calendar=Calendar.getInstance();

2.日历的作用:
看日子
定日子

3.int get(int field) 返回给定日历字段的值。
参数:int field–具体查询的问题

4.void set(int year, int month, int date, int hourOfDay, int minute, int second)

5.设置字段中的值 YEAR , MONTH , DAY_OF_MONTH , HOUR_OF_DAY , MINUTE和 SECOND 。

6.Date getTime() 返回一个 Date表示此物体 Calendar的时间值(毫秒从偏移 Epoch “)。
Calendar 的静态变量:
1.static int YEAR get现场编号和 set表示年份。
2.static int MONTH get和 set字段号表示月份。
3.static int DAY_OF_MONTH get字段编号和 set本月的日期。
4.static int DAY_OF_WEEK get字段编号和 set表示一周中的日期。
5.static int DAY_OF_YEAR get和 set字段编号, set本年度的日数。
6.static int WEEK_OF_YEAR get和 set字段编号, set本年度的周数。
7.static int WEEK_OF_MONTH get和 set字段编号, set当月的周数。
例如:

package com_20200820_1;
import java.text.SimpleDateFormat;
import java.util.Calendar;
import java.util.Date;
public class Test {
public static void main(String[] args) {
//创建Calendar对象
Calendar dar = Calendar.getInstance();
//int get(int field)返回给定日历字段
//int field--给定的日历字段
//YEAR--年
System.out.println("YEAR--"+dar.get(Calendar.YEAR));
//MONTH --月【从0开始数】
System.out.println("MONTH--"+(dar.get(Calendar.MONTH)+1));
//DAY_OF_MONTH--月中的天
System.out.println("DAY_OF_MONTH--月中的天--"+dar.get(Calendar.DAY_OF_MONTH));
//DAY_OF_WEEK---周中的星期【从星期天开始数】
System.out.println("DAY_OF_WEEK---周中的星期--"+(dar.get(Calendar.DAY_OF_WEEK)-1));
//DAY_OF_YEAR---年中的天
System.out.println("//DAY_OF_YEAR---年中的天--"+dar.get(Calendar.DAY_OF_YEAR));
//WEEK_OF_YEAR--年中的周
System.out.println("WEEK_OF_YEAR--年中的周--"+dar.get(Calendar.WEEK_OF_YEAR));
//WEEK_OF_MONTH--月中的周
System.out.println("WEEK_OF_MONTH--月中的周-- "+dar.get(Calendar.WEEK_OF_MONTH));
//set(int year, int month, int date, int hourOfDay, int minute, int second)
//设置字段中的值 YEAR , MONTH , DAY_OF_MONTH , HOUR_OF_DAY , MINUTE和 SECOND 。
dar.set(1998,11,25,12,30,30);
Date te = dar.getTime();
System.out.println(te);
SimpleDateFormat mat = new SimpleDateFormat("yyyy年MM月dd日 HH:mm:ss");
String te2 = mat.format(te);
System.out.println(te2);
}
}

执行结果:
《时间日期的操作类和其他常用类》

二、Date类如何创建对象,有哪些常用方法?

Date类—java.util.Date—子类—java.sql.Date

Date类的定义—public class Date

Date表示特定的时间。
构造方法:
1.Date() 创建一个 Date对象,保存了当前系统时间。【格式不符合我们的认识】
2.Date(long date) 创建一个 Date对象,保存的是从标准基准时间即1970年1月1日00:00:00 GMT到当下所经过的毫秒数的当下时间。
date – 1970年1月1日00:00:00 GMT以来的毫秒数。
实例方法:
1.boolean after(Date when)测试此日期是否在指定日期之后。
2.boolean before(Date when) 测试此日期是否在指定日期之前。
3.boolean equals(Object obj) 比较两个日期来平等。【Date重写过】
4.long getTime() 返回自1970年1月1日以来,由此 Date对象表示的00:00:00 GMT的毫秒 数 。
5.void setTime(long time) 设置此 Date对象以表示1970年1月1日00:00:00 GMT后的 time毫秒的时间点。
6.String toString() 将此 Date对象转换为 String的形式
例如:

package com_20200820_1;
import java.util.Date;
public class Test {
public static void main(String[] args) {
//Date() 创建一个 Date对象,保存了当前系统时间。
Date te1 = new Date();
System.out.println(te1);
//Date(long date) 创建一个 Date对象,保存的是从标准基准时间即1970年1月1日00:00:00 GMT到当下所经过的毫秒数的当下时间。
//参数date - 1970年1月1日00:00:00 GMT以来的毫秒数。
Date te2 = new Date(7000);
System.out.println(te2);
//通过Date(long date)得到当前系统时间:
//1.通过System.currentTimeMillis()得到970年1月1日00:00:00 GMT以来的毫秒数。
long hm = System.currentTimeMillis();
Date te3 = new Date(hm);
System.out.println("当前系统时间"+te3);
//2.通过long getTime() 得到1970年1月1日00:00:00 GMT以来的毫秒数。
long hm2 = te1.getTime();
Date te4 = new Date(hm2);
System.out.println("当前系统时间"+te4);
//boolean after(Date when)测试此日期是否在指定日期之后。
boolean lean = te1.after(te2);
System.out.println(lean);
//boolean before(Date when) 测试此日期是否在指定日期之前。
boolean lean2 = te1.before(te2);
System.out.println(lean2);
//String toString() 将此 Date对象转换为 String的形式.
String str = te1.toString();
System.out.println(str);
}
}

执行结果:
《时间日期的操作类和其他常用类》

三、SimpleDateFormat类如何创建对象,有哪些常用方法?
1.java.text.SimpleDateFormat —格式化和解析日期

2.SimpleDateFormat() 使用默认的时间日期格式

3.SimpleDateFormat(String pattern) 使用给定的时间日期格式

参数–String pattern【描述日期和时间格式的模式】
时间格式的模式:
y—年【yyyy/1998,yy/98】
M–月【MM/08】
d—日【dd/23】
H—时【HH/12】
m–分【mm/23】
s—秒 【ss/56】
S–毫秒【sss/768】
E–星期【E/星期三】
“yyyy年MM月dd日 HH:mm:ss E”
“yyyy/MM/dd HH:mm:ss E”
“yyyy-MM-dd HH:mm:ss E”
“yyyy/MM/dd E HH:mm”
实例方法:
1.String format(Date date) 格式化一个时间日期来生成一个字符串。
2.Date parse(String source) 从给定字符串的开始解析文本以生成日期。
例如:

package com_20200820_1;
import java.text.ParseException;
import java.text.SimpleDateFormat;
import java.util.Date;
public class Test {
public static void main(String[] args) throws ParseException {
//1.将时间转换成指定格式的字符串形式
//得到当前系统时间
Date te1 = new Date();
System.out.println(te1);
//创建一个固定的格式
String geshi = "yyyy/MM/dd E HH:mm";
//创建一个时间日期格式化对象
SimpleDateFormat mat = new SimpleDateFormat(geshi);
//开始格式化时间日期
String str = mat.format(te1);
System.out.println(str);
//2.指定格式的字符串形式的时间日期转换成java.util.Date对象
//自定义日期
String str2 = "1998/11/25 星期五 12:30";
//创建一个固定的格式
String str3 = "yyyy/MM/dd E HH:mm";
//创建一个时间日期格式化对象
SimpleDateFormat mat2 = new SimpleDateFormat(str3);
//解析时间日期字符串成Date
Date str4 = mat2.parse(str2);
System.out.println(str4);
}
}

执行结果:
《时间日期的操作类和其他常用类》

其他常用类

一、.Math类有哪些常用方法?
1.Math定义public final class Math

2.Math类包含执行基本数字运算的方法,如基本指数,对数,平方根和三角函数。

3.Math里面的变量和方法都是静态的,因此是不需要对象访问,通过类型就可以直接调用
静态方法:
1.static double E double值比其他任何一个都更接近 e ,自然对数的基数。
2.static double PI double值比任何其他的更接近 pi ,圆周长与其直径的比率。

3.static long round(double a) 返回参数中最接近的 long ,其中 long四舍五入为正无穷大。 【注意负数】
4.static int round(float a) 返回参数中最接近的 int ,其中 int四舍五入为正无穷大。【注意负数】
5.static double random() 返回值为 double值为正号,大于等于 0.0 ,小于 1.0随机数 。
例如:

package com_20200820_1;
public class Test {
public static void main(String[] args) {
//1.static double E double值比其他任何一个都更接近 e ,自然对数的基数。
System.out.println("自然常数=="+Math.E);
//2.static double PI double值比任何其他的更接近 pi ,圆周长与其直径的比率。
System.out.println("圆周率=="+Math.PI);
//3.static long round(double a) 返回参数中最接近的 long ,其中 long四舍五入为正无穷大。 【注意负数】
System.out.println("round(13.55)=="+Math.round(13.55));
System.out.println("round(-13.55)=="+Math.round(-13.55));
//4.static double random() 返回值为 double值为正号,大于等于 0.0 ,小于 1.0随机数 。
System.out.println("随机数=="+Math.random());
//概率中奖
for(int i=1; i<=10;i++ ) {
int num = ((int)(Math.random()*10))+1;
System.out.println(num);
if(num>7) {
System.out.println("中奖");
}else {
System.out.println("未中奖");
}
}
}
}

执行结果:
《时间日期的操作类和其他常用类》《时间日期的操作类和其他常用类》
二、Scanner类的用法

1.Scanner是在在JDK1.5的时候被新增进入的

2.Scanner从控制台获取输入的数据值。

构造方法:
1.Scanner(InputStream source) 通过一个字节输入流对象创建Scanner对象。
2.参数–InputStream source【字节输入流对象–读取数据】
3.用System.in–字节输入流对象【标准”输入流–键盘输入】
创建对象:Scanner s = new Scanner(System.in);
实例方法:
1.String next() 接收String
2.boolean nextBoolean()接收boolean[true/false]
3.byte nextByte() 接收byte
4.double nextDouble() 接收 double 。
5.float nextFloat() 接收float 。
6.int nextInt() 接收 int 。
7.long nextLong() 接收 long 。
8.short nextShort() 接收short 。
9.String nextLine() 接收一行String。
例如 :

package com_20200820_1;
import java.util.Scanner;
public class Test {
public static void main(String[] args) {
//创建Scanner类对象
Scanner shuru = new Scanner(System.in);
System.out.println("请输入学生编号:");
//int nextInt() 接收 int 。
int id = shuru.nextInt();
System.out.println("请输入学生姓名:");
//String nextLine() 接收一行String。
String name = shuru.next();
System.out.println("请输入学生身高:");
//double nextDouble() 接收 double 。
double height = shuru.nextDouble();
System.out.println("是否毕业:");
//boolean nextBoolean() 接收 double 。
boolean biye = shuru.nextBoolean();
System.out.println("你录入的学生信息是:");
//String nextLine() 接收一行String。
System.out.println(id+"--"+name+"--"+height+"--"+biye);
}
}

执行结果:
《时间日期的操作类和其他常用类》

三、什么是正则表达式,如何创建,如何使用?
正则表达式,又称规则表达式。正则表达式通常被用来检索、替换那些符合某个模式(规则)的文本。

校验数字的表达式

  1. 数字:1*$
  2. n位的数字:^\d{n}$
  3. 至少n位的数字:^\d{n,}$
  4. m-n位的数字:^\d{m,n}$
  5. 零和非零开头的数字:^(0|[1-9][0-9]*)$
  6. 非零开头的最多带两位小数的数字:^([1-9][0-9]*)+(.[0-9]{1,2})?$
  7. 带1-2位小数的正数或负数:^(-)?\d+(.\d{1,2})?$
  8. 正数、负数、和小数:^(-|+)?\d+(.\d+)?$
  9. 有两位小数的正实数:2+(.[0-9]{2})?$
  10. 有1~3位小数的正实数:3+(.[0-9]{1,3})?$
  11. 非零的正整数:4\d*$ 或 ^([1-9][0-9]){1,3}$ 或 ^+?[1-9][0-9]$
  12. 非零的负整数:^-[1-9][]0-9&#8243;$ 或 ^-[1-9]\d$
  13. 非负整数:^\d+$ 或 5\d*|0$
  14. 非正整数:^-[1-9]\d*|0$ 或 ^((-\d+)|(0+))$
  15. 非负浮点数:^\d+(.\d+)?$ 或 6\d*.\d*|0.\d*[1-9]\d*|0?.0+|0$
  16. 非正浮点数:^((-\d+(.\d+)?)|(0+(.0+)?))$ 或 ^(-([1-9]\d*.\d*|0.\d*[1-9]\d*))|0?.0+|0$
  17. 正浮点数:7\d*.\d*|0.\d*[1-9]\d*$ 或 ^(([0-9]+.[0-9][1-9][0-9])|([0-9][1-9][0-9].[0-9]+)|([0-9][1-9][0-9]))$
  18. 负浮点数:^-([1-9]\d*.\d*|0.\d*[1-9]\d*)$ 或 ^(-(([0-9]+.[0-9][1-9][0-9])|([0-9][1-9][0-9].[0-9]+)|([0-9][1-9][0-9])))$
  19. 浮点数:^(-?\d+)(.\d+)?$ 或 ^-?([1-9]\d*.\d*|0.\d*[1-9]\d*|0?.0+|0)$
    校验字符的表达式
  20. 汉字:8{0,}$
  21. 英文和数字:9+$ 或 10{4,40}$
  22. 长度为3-20的所有字符:^.{3,20}$
  23. 由26个英文字母组成的字符串:11+$
  24. 由26个大写英文字母组成的字符串:12+$
  25. 由26个小写英文字母组成的字符串:13+$
  26. 由数字和26个英文字母组成的字符串:14+$
  27. 由数字、26个英文字母或者下划线组成的字符串:^\w+$ 或 ^\w{3,20}$
  28. 中文、英文、数字包括下划线:15+$
  29. 中文、英文、数字但不包括下划线等符号:16+$ 或 17{2,20}$
  30. 可以输入含有^%&’,;=?KaTeX parse error: Can&#8217;t use function &#8216;\&#8221;&#8216; in math mode at position 1: \̲&#8221;̲等字符:[^%&&#8217;,;=?\x22]+ 12 禁止输入含有的字符:[^\x22]+
    其它:
    .*匹配除 \n 以外的任何字符。
    /[\u4E00-\u9FA5]/ 汉字
    /[\uFF00-\uFFFF]/ 全角符号
    /[\u0000-\u00FF]/ 半角符号
    三、特殊需求表达式
  31. Email地址:^\w+([-+.]\w+)@\w+([-.]\w+).\w+([-.]\w+)*$
  32. 域名:[a-zA-Z0-9][-a-zA-Z0-9]{0,62}(/.[a-zA-Z0-9][-a-zA-Z0-9]{0,62})+/.?
  33. InternetURL:[a-zA-z]+://[^\s]* 或 ^http://([\w-]+.)+[\w-]+(/[\w-./?%&=]*)?$
  34. 手机号码:^(13[0-9]|14[5|7]|15[0|1|2|3|5|6|7|8|9]|18[0|1|2|3|5|6|7|8|9])\d{8}$
  35. 电话号码(“XXX-XXXXXXX”、“XXXX-XXXXXXXX”、“XXX-XXXXXXX”、“XXX-XXXXXXXX”、&#8221;XXXXXXX&#8221;和&#8221;XXXXXXXX):^((\d{3,4}-)|\d{3.4}-)?\d{7,8}$
  36. 国内电话号码(0511-4405222、021-87888822):\d{3}-\d{8}|\d{4}-\d{7}
  37. 身份证号(15位、18位数字):^\d{15}|\d{18}$
  38. 短身份证号码(数字、字母x结尾):^([0-9]){7,18}(x|X)?$ 或 ^\d{8,18}|[0-9x]{8,18}|[0-9X]{8,18}?$
  39. 帐号是否合法(字母开头,允许5-16字节,允许字母数字下划线):18[a-zA-Z0-9_]{4,15}$
  40. 密码(以字母开头,长度在6~18之间,只能包含字母、数字和下划线):19\w{5,17}$
  41. 强密码(必须包含大小写字母和数字的组合,不能使用特殊字符,长度在8-10之间):^(?=.\d)(?=.[a-z])(?=.*[A-Z]).{8,10}$
  42. 日期格式:^\d{4}-\d{1,2}-\d{1,2}
  43. 一年的12个月(01~09和1~12):^(0?[1-9]|1[0-2])$
  44. 一个月的31天(01~09和1~31):^((0?[1-9])|((1|2)[0-9])|30|31)$
  45. 钱的输入格式:
  46. 1.有四种钱的表示形式我们可以接受:“10000.00” 和 “10,000.00”, 和没有 “分” 的 “10000” 和 “10,000”:20[0-9]*$
  47. 2.这表示任意一个不以0开头的数字,但是,这也意味着一个字符&#8221;0&#8243;不通过,所以我们采用下面的形式:^(0|[1-9][0-9]*)$
  48. 3.一个0或者一个不以0开头的数字.我们还可以允许开头有一个负号:^(0|-?[1-9][0-9]*)$
  49. 4.这表示一个0或者一个可能为负的开头不为0的数字.让用户以0开头好了.把负号的也去掉,因为钱总不能是负的吧.下面我们要加的是说明可能的小数部分:21+(.[0-9]+)?$
  50. 5.必须说明的是,小数点后面至少应该有1位数,所以&#8221;10.&#8221;是不通过的,但是 “10” 和 “10.2” 是通过的:22+(.[0-9]{2})?$
  51. 6.这样我们规定小数点后面必须有两位,如果你认为太苛刻了,可以这样:23+(.[0-9]{1,2})?$
  52. 7.这样就允许用户只写一位小数.下面我们该考虑数字中的逗号了,我们可以这样:24{1,3}(,[0-9]{3})(.[0-9]{1,2})?$
    23 8.1到3个数字,后面跟着任意个 逗号+3个数字,逗号成为可选,而不是必须:^([0-9]+|[0-9]{1,3}(,[0-9]{3})
    )(.[0-9]{1,2})?$
  53. 备注:这就是最终结果了,别忘了&#8221;+“可以用”*&#8221;替代如果你觉得空字符串也可以接受的话(奇怪,为什么?)最后,别忘了在用函数时去掉去掉那个反斜杠,一般的错误都在这里
  54. xml文件:^([a-zA-Z]±?)+[a-zA-Z0-9]+\.[x|X][m|M][l|L]$
  55. 中文字符的正则表达式:[\u4e00-\u9fa5]
  56. 双字节字符:[^\x00-\xff] (包括汉字在内,可以用来计算字符串的长度(一个双字节字符长度计2,ASCII字符计1))
  57. 空白行的正则表达式:\n\s*\r (可以用来删除空白行)
  58. HTML标记的正则表达式:<(\S*?)[^>]>.?|<.*? /> (网上流传的版本太糟糕,上面这个也仅仅能部分,对于复杂的嵌套标记依旧无能为力)
  59. 首尾空白字符的正则表达式:^\s*|\s*KaTeX parse error: Undefined control sequence: \s at position 4: 或(^\̲s̲*)|(\s*) (可以用来删除行首行尾的空白字符(包括空格、制表符、换页符等等),非常有用的表达式)
  60. 腾讯QQ号:[1-9][0-9]{4,} (腾讯QQ号从10000开始)
  61. 中国邮政编码:[1-9]\d{5}(?!\d) (中国邮政编码为6位数字)
  62. IP地址:\d+.\d+.\d+.\d+ (提取IP地址时有用)
  63. IP地址:((?: (?:25[0-5]|2[0-4]\d|[01]?\d?\d)\.){3}(?:25[0-5]|2[0-4]\d|[01]?\d?\d))
  64. IP-v4地址:\b(?: (? :25[0-5]|2[0-4][0-9]|[01]?[0-9][0-9]?)\.){3}(?:25[0-5]|2[0-4][0-9]|[01]?[0-9][0-9]?)\b (提取IP地址时有用)
  65. 校验IP-v6地址:(([0-9a-fA-F]{1,4}: ){7,7}[0-9a-fA-F]{1,4}|([0-9a-fA-F]{1,4}: ){1,7}: |([0-9a-fA-F]{1,4}: ){1,6}:[0-9a-fA-F]{1,4}|([0-9a-fA-F]{1,4}: ){1,5}(:[0-9a-fA-F]{1,4}){1,2}|([0-9a-fA-F]{1,4}: ){1,4}(:[0-9a-fA-F]{1,4}){1,3}|([0-9a-fA-F]{1,4}: ){1,3}(:[0-9a-fA-F]{1,4}){1,4}|([0-9a-fA-F]{1,4}: ){1,2}(:[0-9a-fA-F]{1,4}){1,5}|[0-9a-fA-F]{1,4}: ((:[0-9a-fA-F]{1,4}){1,6})|:((:[0-9a-fA-F]{1,4}){1,7}|: )|fe80:(:[0-9a-fA-F]{0,4}){0,4}%[0-9a-zA-Z]{1,}|::(ffff(:0{1,4}){0,1}: ){0,1}((25[0-5]|(2[0-4]|1{0,1}[0-9]){0,1}[0-9])\.){3,3}(25[0-5]|(2[0-4]|1{0,1}[0-9]){0,1}[0-9])|([0-9a-fA-F]{1,4}: ){1,4}: ((25[0-5]|(2[0-4]|1{0,1}[0-9]){0,1}[0-9])\.){3,3}(25[0-5]|(2[0-4]|1{0,1}[0-9]){0,1}[0-9]))
  66. 子网掩码:((?: (?:25[0-5]|2[0-4]\d|[01]?\d?\d)\.){3}(?:25[0-5]|2[0-4]\d|[01]?\d?\d))
  67. 校验日期:^(?: (?!0000)[0-9]{4}-(?: (?:0[1-9]|1[0-2])-(?:0[1-9]|1[0-9]|2[0-8])|(?:0[13-9]|1[0-2])-(?:29|30)|(?:0[13578]|1[02])-31)|(?:[0-9]{2}(?:0[48]|[2468][048]|[13579][26])|(?:0[48]|[2468][048]|[13579][26])00)-02-29)$(“yyyy-mm-dd“ 格式的日期校验,已考虑平闰年。)
  68. 抽取注释:
  69. 查找CSS属性:^\s*[a-zA-Z\-]+\s*[:]{1}\s[a-zA-Z0-9\s.#]+[;]{1}
  70. 提取页面超链接:(\brel=)[^>])(href=“https?:\/\/)((?!(?: (?:www\.)?’.implode(’|(?:www\.)?’, $follow_list).’))[^” rel=“external nofollow” ]+)&#8221;((?!.\brel=)[>]*)(?:[>])>
  71. 提取网页图片:\<[img][^\\>][src] *= [\&#8221;\’]{0,1}([^\&#8221;\’\ >])
  72. 提取网页颜色代码:^#([A-Fa-f0-9]{6}|[A-Fa-f0-9]{3})$
  73. 文件扩展名效验:^([a-zA-Z]\: |\\)\\([\\]+\\)*[\/: *?&#8221;<>|]+\.txt(l)?$
  74. 判断IE版本:^.*MSIE 5-8?(?!.Trident\/[5-9]\.0).$

匹配正则表达式
1.String类的matchs匹配正则表达式
例如:

package com_20200820_1;
import java.util.Scanner;
public class Test {
public static void main(String[] args) {
//创建一个正则表达式
String regex = "^(13[0-9]|14[5|7]|15[0|1|2|3|5|6|7|8|9]|18[0|1|2|3|5|6|7|8|9])\\d{8}$";
//创建Scanner类的对象
Scanner shu = new Scanner(System.in);
System.out.println("请输入手机号");
//接受手机号
String phone = shu.next();
//匹配手机号
boolean flag = phone.matches(regex);
if(flag) {
System.out.print("你输入的手机号码合法!");
}else {
System.out.print("你输入的手机号码不合法!");
}
}
}

执行结果:
《时间日期的操作类和其他常用类》
2.java.util.regex 包主要包括以下两个类:
Pattern 类:【创建】
pattern 对象是一个正则表达式的编译表示。Pattern 类没有公共构造方法。要创建一个 Pattern 对象,你必须首先调用其公共静态编译方法,它返回一个 Pattern 对象。该方法接受一个正则表达式作为它的第一个参数。
Matcher 类:【匹配】
Matcher 对象是对输入字符串进行解释和匹配操作的引擎。与Pattern 类一样,Matcher 也没有公共构造方法。你需要调用 Pattern 对象的 matcher 方法来获得一个 Matcher 对象。
例如:

package com_20200820_1;
import java.util.Scanner;
import java.util.regex.Pattern;
public class Test2 {
public static void main(String[] args) {
Scanner read=new Scanner(System.in);
System.out.println("请输入手机号码");
String phone=read.next();
//创建一个正则表达式
String pattern ="^(13[0-9]|14[5|7]|15[0|1|2|3|5|6|7|8|9]|18[0|1|2|3|5|6|7|8|9])\\d{8}$";
boolean flag=Pattern.matches(pattern, phone);
if(flag) {
System.out.print("你输入的手机号码合法!!");
}else {
System.out.print("你输入的手机号码不合法!!");
}
}
}

执行结果:
《时间日期的操作类和其他常用类》
例如:

package com_20200820_1;
import java.util.regex.Matcher;
import java.util.regex.Pattern;
public class Test3 {
public static void main(String[] args) {
// 按指定模式在字符串查找
String line = "This order was placed for QT3000! OK?";
String pattern = "(\\D*)(\\d+)(.*)";
// 创建 Pattern 对象
Pattern r = Pattern.compile(pattern);
// 现在创建 matcher 对象
Matcher m = r.matcher(line);
if (m.find( )) {
System.out.println("Found value: " + m.group(0) );
System.out.println("Found value: " + m.group(1) );
System.out.println("Found value: " + m.group(2) );
System.out.println("Found value: " + m.group(3) );
} else {
System.out.println("NO MATCH");
}
}
}

执行结果:
《时间日期的操作类和其他常用类》

  1. 0-9 &#x21a9;︎

  2. 0-9 &#x21a9;︎

  3. 0-9 &#x21a9;︎

  4. 1-9 &#x21a9;︎

  5. 1-9 &#x21a9;︎

  6. 1-9 &#x21a9;︎

  7. 1-9 &#x21a9;︎

  8. \u4e00-\u9fa5 &#x21a9;︎

  9. A-Za-z0-9 &#x21a9;︎

  10. A-Za-z0-9 &#x21a9;︎

  11. A-Za-z &#x21a9;︎

  12. A-Z &#x21a9;︎

  13. a-z &#x21a9;︎

  14. A-Za-z0-9 &#x21a9;︎

  15. \u4E00-\u9FA5A-Za-z0-9_ &#x21a9;︎

  16. \u4E00-\u9FA5A-Za-z0-9 &#x21a9;︎

  17. \u4E00-\u9FA5A-Za-z0-9 &#x21a9;︎

  18. a-zA-Z &#x21a9;︎

  19. a-zA-Z &#x21a9;︎

  20. 1-9 &#x21a9;︎

  21. 0-9 &#x21a9;︎

  22. 0-9 &#x21a9;︎

  23. 0-9 &#x21a9;︎

  24. 0-9 &#x21a9;︎


推荐阅读
  • 使用Maven JAR插件将单个或多个文件及其依赖项合并为一个可引用的JAR包
    本文介绍了如何利用Maven中的maven-assembly-plugin插件将单个或多个Java文件及其依赖项打包成一个可引用的JAR文件。首先,需要创建一个新的Maven项目,并将待打包的Java文件复制到该项目中。通过配置maven-assembly-plugin,可以实现将所有文件及其依赖项合并为一个独立的JAR包,方便在其他项目中引用和使用。此外,该方法还支持自定义装配描述符,以满足不同场景下的需求。 ... [详细]
  • 本文介绍了一种自定义的Android圆形进度条视图,支持在进度条上显示数字,并在圆心位置展示文字内容。通过自定义绘图和组件组合的方式实现,详细展示了自定义View的开发流程和关键技术点。示例代码和效果展示将在文章末尾提供。 ... [详细]
  • 使用 ListView 浏览安卓系统中的回收站文件 ... [详细]
  • Python 程序转换为 EXE 文件:详细解析 .py 脚本打包成独立可执行文件的方法与技巧
    在开发了几个简单的爬虫 Python 程序后,我决定将其封装成独立的可执行文件以便于分发和使用。为了实现这一目标,首先需要解决的是如何将 Python 脚本转换为 EXE 文件。在这个过程中,我选择了 Qt 作为 GUI 框架,因为之前对此并不熟悉,希望通过这个项目进一步学习和掌握 Qt 的基本用法。本文将详细介绍从 .py 脚本到 EXE 文件的整个过程,包括所需工具、具体步骤以及常见问题的解决方案。 ... [详细]
  • 分享一款基于Java开发的经典贪吃蛇游戏实现
    本文介绍了一款使用Java语言开发的经典贪吃蛇游戏的实现。游戏主要由两个核心类组成:`GameFrame` 和 `GamePanel`。`GameFrame` 类负责设置游戏窗口的标题、关闭按钮以及是否允许调整窗口大小,并初始化数据模型以支持绘制操作。`GamePanel` 类则负责管理游戏中的蛇和苹果的逻辑与渲染,确保游戏的流畅运行和良好的用户体验。 ... [详细]
  • Python 伦理黑客技术:深入探讨后门攻击(第三部分)
    在《Python 伦理黑客技术:深入探讨后门攻击(第三部分)》中,作者详细分析了后门攻击中的Socket问题。由于TCP协议基于流,难以确定消息批次的结束点,这给后门攻击的实现带来了挑战。为了解决这一问题,文章提出了一系列有效的技术方案,包括使用特定的分隔符和长度前缀,以确保数据包的准确传输和解析。这些方法不仅提高了攻击的隐蔽性和可靠性,还为安全研究人员提供了宝贵的参考。 ... [详细]
  • C++ 异步编程中获取线程执行结果的方法与技巧及其在前端开发中的应用探讨
    本文探讨了C++异步编程中获取线程执行结果的方法与技巧,并深入分析了这些技术在前端开发中的应用。通过对比不同的异步编程模型,本文详细介绍了如何高效地处理多线程任务,确保程序的稳定性和性能。同时,文章还结合实际案例,展示了这些方法在前端异步编程中的具体实现和优化策略。 ... [详细]
  • 在处理 XML 数据时,如果需要解析 `` 标签的内容,可以采用 Pull 解析方法。Pull 解析是一种高效的 XML 解析方式,适用于流式数据处理。具体实现中,可以通过 Java 的 `XmlPullParser` 或其他类似的库来逐步读取和解析 XML 文档中的 `` 元素。这样不仅能够提高解析效率,还能减少内存占用。本文将详细介绍如何使用 Pull 解析方法来提取 `` 标签的内容,并提供一个示例代码,帮助开发者快速解决问题。 ... [详细]
  • 在Java Web服务开发中,Apache CXF 和 Axis2 是两个广泛使用的框架。CXF 由于其与 Spring 框架的无缝集成能力,以及更简便的部署方式,成为了许多开发者的首选。本文将详细介绍如何使用 CXF 框架进行 Web 服务的开发,包括环境搭建、服务发布和客户端调用等关键步骤,为开发者提供一个全面的实践指南。 ... [详细]
  • QT框架中事件循环机制及事件分发类详解
    在QT框架中,QCoreApplication类作为事件循环的核心组件,为应用程序提供了基础的事件处理机制。该类继承自QObject,负责管理和调度各种事件,确保程序能够响应用户操作和其他系统事件。通过事件循环,QCoreApplication实现了高效的事件分发和处理,使得应用程序能够保持流畅的运行状态。此外,QCoreApplication还提供了多种方法和信号槽机制,方便开发者进行事件的定制和扩展。 ... [详细]
  • 本文深入探讨了Java多线程环境下的同步机制及其应用,重点介绍了`synchronized`关键字的使用方法和原理。`synchronized`关键字主要用于确保多个线程在访问共享资源时的互斥性和原子性。通过具体示例,如在一个类中使用`synchronized`修饰方法,展示了如何实现线程安全的代码块。此外,文章还讨论了`ReentrantLock`等其他同步工具的优缺点,并提供了实际应用场景中的最佳实践。 ... [详细]
  • 本文介绍了如何利用ObjectMapper实现JSON与JavaBean之间的高效转换。ObjectMapper是Jackson库的核心组件,能够便捷地将Java对象序列化为JSON格式,并支持从JSON、XML以及文件等多种数据源反序列化为Java对象。此外,还探讨了在实际应用中如何优化转换性能,以提升系统整体效率。 ... [详细]
  • 开发日志:201521044091 《Java编程基础》第11周学习心得与总结
    开发日志:201521044091 《Java编程基础》第11周学习心得与总结 ... [详细]
  • 在使用 SQLAlchemy 时,笔者偶然发现了一个关于 `NULL` 比较的有趣现象。具体来说,当使用 `Column(x).is_(null())` 进行比较时,其行为与预期有所不同。本文将深入探讨这一问题,并提出相应的解决方案,以确保在处理 `NULL` 值时代码的可交换性和一致性。 ... [详细]
  • 在本节课程中,我们将深入探讨 JSP 编程中的实际案例,通过具体代码示例 `code316.java` 来解析数据库连接的实现。该示例展示了如何使用 Java 的 JDBC API 进行数据库操作,包括加载数据库驱动、建立连接等关键步骤。通过本课程的学习,读者将能够更好地理解和应用 JSP 中的数据库连接技术。 ... [详细]
author-avatar
七月de七月小
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有