使用正则表达式判断身份证号是否合法

本文介绍如何使用正则表达式来判断一个身份证号码是否合法,既包括15位也包括18位的情况,其中18位的身份证号码允许最后一位为字母。通过正则模式匹配,确保身份证号码的日期部分符合实际日期格式。示例代码展示了具体实现过程。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

判断身份证:要么是15位,要么是18位,最后⼀位可以为字母,并写程序提出其中的年月日。

思路:

  1. 我们可以⽤正则表达式来定义复杂的字符串格式,(\d{17}[0-9a-zA-Z]|\d{14}[0-9a-zA-Z])可以⽤来判断是否为合法的15位或18位身份证号码。
  2. 15位和18位的身份证号码都是从7位到第12位为身份证为⽇期类型。这样可以设计出更精确的正则模式,使身份证号的⽇期合法,这样我们的正则模式可以进⼀步将⽇期部分的正则修改为 [12][0-9]\\d{2}[01][0-9][123][0-9] ,当然可以更精确的设置⽇期。
  3. 使用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("");
          }
  
      }
  }
  
  
  1. 结果:
身份证号445381199807129201合法
生日信息为19980712
具体年月日为:1998年07月12日

身份证号13068119871209201x合法

身份证号13068119871209201不合法

身份证号123456789012345合法

身份证号12345678901234x合法

身份证号1234567890123不合法

### 回答1: 在 Java使用正则表达式判断身份证号码可以使用 `java.util.regex` 包中的 `Pattern` 和 `Matcher` 类。 首先,需要编写正则表达式来匹配身份证号码的格式。身份证号码的格式一般为 18 位数字,最后一位可能是数字或字母(X)。所以正则表达式可以写成: ``` ^[0-9]{17}[0-9X]$ ``` 然后,使用 `Pattern` 类的 `compile` 方法将正则表达式编译为一个 `Pattern` 对象,然后使用 `Matcher` 类的 `matches` 方法来判断身份证号是否符合这个格式。 代码如下: ``` import java.util.regex.Matcher; import java.util.regex.Pattern; public class IDCardNumberValidator { private static final String ID_CARD_NUMBER_PATTERN = "^[0-9]{17}[0-9X]$"; public static boolean isValid(String idCardNumber) { Pattern pattern = Pattern.compile(ID_CARD_NUMBER_PATTERN); Matcher matcher = pattern.matcher(idCardNumber); return matcher.matches(); } } ``` 调用 `IDCardNumberValidator.isValid` 方法时,传入的参数 `idCardNumber` 就是要判断身份证号码,如果该身份证号码符合身份证号码的格式,就会返回 `true`,否则返回 `false`。 例如: ``` boolean isValid = IDCardNumberValidator.isValid("123456789012345678"); ``` 这里的 `isValid` 变量的值为 `true`。 但是,正则表达式只能用于判断身份证号码的格式是 ### 回答2: 在Java使用正则表达式判断身份证号可以通过Pattern和Matcher类来实现。 首先,我们需要定义一个正则表达式,用于匹配身份证号身份证号的格式为18位,前17位是数字,最后一位可能是数字或字母(X或x表示10),我们可以使用正则表达式"^\d{17}(\d|X|x)$"来匹配。 接下来,我们可以使用Pattern类将正则表达式编译成一个Pattern对象,并使用Matcher类来进行匹配操作。 示例代码如下: ```java import java.util.regex.*; public class Main { public static void main(String[] args) { String idNumber = "123456789012345678"; // 定义身份证号正则表达式 String regex = "^\\d{17}(\\d|X|x)$"; // 编译正则表达式 Pattern pattern = Pattern.compile(regex); // 创建Matcher对象 Matcher matcher = pattern.matcher(idNumber); // 进行匹配判断 if (matcher.matches()) { System.out.println("身份证号格式正确"); } else { System.out.println("身份证号格式不正确"); } } } ``` 以上代码中,我们将待检查的身份证号赋值给idNumber变量,然后将正则表达式赋值给regex变量。接着,我们使用Pattern类的compile方法编译正则表达式,创建Pattern对象。然后,使用Matcher类的matcher方法,传入待检查的身份证号,创建Matcher对象。最后,通过调用matches方法进行匹配判断,如果匹配成功则输出"身份证号格式正确",否则输出"身份证号格式不正确"。 需要注意的是,这只是一个简单的示例,实际中可能还需要考虑其他因素,比如判断身份证号中的出生日期是否合法等。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

zjojk

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值