scala中的字符串-身份证中的秘密(下)

27 阅读4分钟

编写程序,实现效果。

从键盘上输入一个身份证号,输出判断结果

籍贯:湖北省

性别:男

年龄:40

生日:06-11

星座:巨蟹

性格:

代码如下:

package string

import java.time.LocalDate
import java.time.format.DateTimeFormatter
import java.time.temporal.ChronoUnit

/*
* 任务: 从键盘输入一个身份证号。
* 写程序,提取信息
*      1.性别
**/
object string03 {

  // 身份证前两位地区映射
  val regionMap: Map[String, String] = Map(
    "11" -> "北京市", "12" -> "天津市", "13" -> "河北省", "14" -> "山西省", "15" -> "内蒙古自治区",
    "21" -> "辽宁省", "22" -> "吉林省", "23" -> "黑龙江省",
    "31" -> "上海市", "32" -> "江苏省", "33" -> "浙江省", "34" -> "安徽省", "35" -> "福建省",
    "36" -> "江西省", "37" -> "山东省", "41" -> "河南省", "42" -> "湖北省", "43" -> "湖南省",
    "44" -> "广东省", "45" -> "广西壮族自治区", "46" -> "海南省", "50" -> "重庆市", "51" -> "四川省",
    "52" -> "贵州省", "53" -> "云南省", "54" -> "西藏自治区", "61" -> "陕西省", "62" -> "甘肃省",
    "63" -> "青海省", "64" -> "宁夏回族自治区", "65" -> "新疆维吾尔自治区", "71" -> "台湾省",
    "81" -> "香港特别行政区", "82" -> "澳门特别行政区"
  )

  // 星座日期范围定义
  private val zodiacRanges = List(
    ((3, 21), (4, 19), "白羊座"),
    ((4, 20), (5, 20), "金牛座"),
    ((5, 21), (6, 21), "双子座"),
    ((6, 22), (7, 22), "巨蟹座"),
    ((7, 23), (8, 22), "狮子座"),
    ((8, 23), (9, 22), "处女座"),
    ((9, 23), (10, 23), "天秤座"),
    ((10, 24), (11, 22), "天蝎座"),
    ((11, 23), (12, 21), "射手座"),
    ((12, 22), (1, 19), "摩羯座"),
    ((1, 20), (2, 18), "水瓶座"),
    ((2, 19), (3, 20), "双鱼座")
  )

  // 函数
  def getZodiacPersonality(zodiac: String): String = {
    zodiac match {
      case "白羊座" => "热情勇敢、行动力强、冲动直接、领导力强"
      case "金牛座" => "稳重务实、有耐心、固执保守、追求稳定"
      case "双子座" => "聪明机智、好奇心强、善变灵活、沟通能力好"
      case "巨蟹座" => "情感细腻、家庭观念强、敏感多疑、保护欲强"
      case "狮子座" => "自信大方、有领导力、爱面子、慷慨热情"
      case "处女座" => "细心谨慎、追求完美、分析力强、有些挑剔"
      case "天秤座" => "优雅和谐、公正平衡、犹豫不决、社交能力强"
      case "天蝎座" => "深沉神秘、直觉敏锐、占有欲强、意志坚定"
      case "射手座" => "乐观开朗、热爱自由、冒险精神、直率坦诚"
      case "摩羯座" => "务实稳重、责任感强、目标明确、有些保守"
      case "水瓶座" => "独立思考、创新思维、友善博爱、略显叛逆"
      case "双鱼座" => "温柔浪漫、富有同情心、想象力丰富、敏感脆弱"
      case _ => "性格特征未知"
    }
  }

  def main(args: Array[String]): Unit = {
//    println("请输入身份证号码:")
//    val idCard = scala.io.StdIn.readLine().trim
    val idCard = "429005198406250053"

    if (validateIdCard(idCard)) {
      analyzeIdCard(idCard)
    } else {
      println("身份证号码格式错误!")
    }
  }

  /**
   * 根据月份和日期判断星座
   * @param month 月份 (1-12)
   * @param day 日期 (1-31)
   * @return 星座名称
   */
  def getZodiac(month: Int, day: Int): String = {
    require(month >= 1 && month <= 12, "月份必须在1-12之间")
    require(day >= 1 && day <= 31, "日期必须在1-31之间")

    // 将日期转换为统一格式进行比较
    val dateValue = month * 100 + day

    zodiacRanges.find { case ((startMonth, startDay), (endMonth, endDay), _) =>
      val startValue = startMonth * 100 + startDay
      val endValue = endMonth * 100 + endDay

      if (startMonth <= endMonth) {
        // 正常区间(同一年内)
        dateValue >= startValue && dateValue <= endValue
      } else {
        // 跨年区间(摩羯座、水瓶座、双鱼座)
        dateValue >= startValue || dateValue <= endValue
      }
    }.map(_._3).getOrElse("未知星座")
  }

  def validateIdCard(idCard: String): Boolean = {
    idCard.matches("^[1-9]\d{5}(18|19|20)\d{2}((0[1-9])|(1[0-2]))(([0-2][1-9])|10|20|30|31)\d{3}[0-9Xx]$")
  }

  def analyzeIdCard(idCard: String): Unit = {
    // 提取地区代码
    val regionCode = idCard.substring(0, 2)
    val region = regionMap.getOrElse(regionCode, "未知地区")

    // 提取性别(第17位,奇数为男,偶数为女)
    val genderDigit = idCard.charAt(16).toString.toInt
    val gender = if (genderDigit % 2 == 1) "男" else "女"

    // 提取生日
    val birthdayStr = idCard.substring(6, 14)
    val formatter = DateTimeFormatter.ofPattern("yyyyMMdd")
    val birthday = LocalDate.parse(birthdayStr, formatter)
    val formattedBirthday = birthday.format(DateTimeFormatter.ofPattern("yyyy-MM-dd"))

    // 计算年龄
    val currentDate = LocalDate.now()
    val age = ChronoUnit.YEARS.between(birthday, currentDate).toInt

    // 提取月份
    val month = idCard.substring(10, 12).toInt
    // 提取日期
    val day = idCard.substring(12, 14).toInt

    val zodiac =  getZodiac(month, day)

    val personality= getZodiacPersonality(zodiac)

    // 输出结果
    println("身份证信息分析结果:")
    println("籍贯:" + region)
    println("性别:" + gender)
    println("年龄:" + age + "岁")
    println("生日:" + formattedBirthday)
    println("星座:" + zodiac)
    println("性格:" + personality)
  }
}