- 任务: 从键盘输入一个身份证号。
- 写程序,提取信息
- 1.性别
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 = {
val idCard = "429005198406250053"
if (validateIdCard(idCard)) {
analyzeIdCard(idCard)
} else {
println("身份证号码格式错误!")
}
}
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, "未知地区")
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)
}
}