zoukankan      html  css  js  c++  java
  • 判断身份证: 要么是 15 位, 要么是 18 位, 最后一位可以 为字母, 并写程序提出其中的年月日。

    答: 我们可以用正则表达式来定义复杂的字符串格式, (d{17}[0-9a-zA-Z]|d{14}[0-9a-zA-Z])可以用来判断
    是否为合法的 15 位或 18 位身份证号码。
    因为 15 位和 18 位的身份证号码都是从 7 位到第 12 位为身份证为日期类型。这样我们可以设计出更精确的
    正则模式, 使身份证号的日期合法, 这样我们的正则模式可以进一步将日期部分的正则修改为
    [12][0-9]{3}[01][0-9][123][0-9], 当然可以更精确的设置日期。
    jdk java.util.Regex 包中有实现正则的类,Pattern Matcher。 以下是实现代码:

    package com.aspire.test;
    
    import java.util.regex.Matcher;
    import java.util.regex.Pattern;
    
    public class Test {
        public static void main(String[] args) {
            
            // 测试是否为合法的身份证号码
            String[] strs = { "130681198712092019", "13068119871209201x",
                    "13068119871209201", "123456789012345", "12345678901234x",
                    "1234567890123" };
            Pattern p1 = Pattern.compile("(\d{17}[0-9a-zA-Z]|\d{14}[0-9a-zA-Z])");
            for (int i = 0; i < strs.length; i++) {
                Matcher matcher = p1.matcher(strs[i]);
                System.out.println(strs[i] + ":" + matcher.matches());
            }
    
            Pattern p2 = Pattern.compile("\d{6}(\d{8}).*"); // 用于提取出生日字符串
            Pattern p3 = Pattern.compile("(\d{4})(\d{2})(\d{2})");// 用于将生日字符串进行分解为年月日
            for (int i = 0; i < strs.length; i++) {
                Matcher matcher = p2.matcher(strs[i]);
                boolean b = matcher.find();
                if (b) {
                    String s = matcher.group(1);
                    System.out.println(s);
                    Matcher matcher2 = p3.matcher(s);
                    if (matcher2.find()) {
                        System.out
                                .println("生日为" + matcher2.group(1) + "年"
                                        + matcher2.group(2) + "月"
                                        + matcher2.group(3) + "日");
                    }
                }
    
            }
        }
    }
  • 相关阅读:
    第四届图灵赛A题谷神的赌博游戏
    poj1562DFS
    数组-03. 冒泡法排序(20)
    数组-02. 打印杨辉三角(20)
    数组-01. 字符转换(15)
    循环-28. 求给定序列前N项和之六(15)
    循环-27. 求给定序列前N项和之五(15)
    循环-26. 求给定序列前N项和之四(15)
    循环-25. 求给定序列前N项和之三(15)
    循环-24. 求给定序列前N项和之二(15)
  • 原文地址:https://www.cnblogs.com/zhaideyou/p/5928460.html
Copyright © 2011-2022 走看看