判断身份证:要么是15位,要么是18位,最后⼀位可以为字母,并写程序提出其中的年月日。
思路:
- 我们可以⽤正则表达式来定义复杂的字符串格式,(\d{17}[0-9a-zA-Z]|\d{14}[0-9a-zA-Z])可以⽤来判断是否为合法的15位或18位身份证号码。
- 15位和18位的身份证号码都是从7位到第12位为身份证为⽇期类型。这样可以设计出更精确的正则模式,使身份证号的⽇期合法,这样我们的正则模式可以进⼀步将⽇期部分的正则修改为 [12][0-9]\\d{2}[01][0-9][123][0-9] ,当然可以更精确的设置⽇期。
- 使用jdk的java.util.Regex包中的Pattern和Matcher。
代码实现:
package com.dgut.test.demo7;
import java.util.regex.Matcher;
import java.util.regex.Pattern;
public class Test {
public static void main(String[] args) {
String[] strs = {"445381199807129201", "13068119871209201x",
"13068119871209201", "123456789012345","12345678901234x", "1234567890123" };
//正则表达式p1,用来判断身份证格式是否合法
Pattern p1 = Pattern.compile("(\\d{17}[0-9a-zA-Z])|(\\d{14}[0-9a-zA-Z])");
//正则表达式p2,用来提取身份证中的生日
Pattern p2 = Pattern.compile("\\d{6}([12][0-9]\\d{2}[01][0-9][123][0-9]).*");
//正则表达式p3,用来获取具体的年月日信息
Pattern p3 = Pattern.compile("(\\d{4})(\\d{2})(\\d{2})");
for (int i = 0; i < strs.length; i++) {
Matcher matcher = p1.matcher(strs[i]);
if (matcher.matches()){
System.out.println("身份证号" + strs[i] + "合法");
Matcher matcher1 = p2.matcher(strs[i]);
if (matcher1.find()){
System.out.println("生日信息为" + matcher1.group(1));
String s = matcher1.group(1);
Matcher matcher2 = p3.matcher(s);
if (matcher2.find())
System.out.println("具体年月日为:" + matcher2.group(1) + "年" + matcher2.group(2) + "月" + matcher2.group(3) + "日");
}
}else {
System.out.println("身份证号" + strs[i] + "不合法");
}
System.out.println("");
}
}
}
- 结果:
身份证号445381199807129201合法
生日信息为19980712
具体年月日为:1998年07月12日
身份证号13068119871209201x合法
身份证号13068119871209201不合法
身份证号123456789012345合法
身份证号12345678901234x合法
身份证号1234567890123不合法