识别一串身份证是否是真实的身份证号码:
公民身份号码是特征组合码,共18位,由17位数字本体码和1位数字校验码组成。 排列顺序从左至右依次为:
6位数字地址码,8位数字出生日期码,3位数字顺序码和1位数字校验码。
作为尾号的校验码,是由号码编制单位按统一的公式计算出来的。
身份证第18位(校验码)的计算方法:
1、将前面的身份证号码17位数分别乘以不同的系数。
从第一位到第十七位的系数分别为: [7,9,10,5,8,4,2,1,6,3,7,9,10,5,8,4,2]。
2、将身份证前17位数字和系数相乘的结果相加。
3、用加出来的和除以11,看余数是多少?
4、余数只可能有[0,1,2,3,4,5,6,7,8,9,10]这11个数字。
其分别对应的最后一位身份证的号码为 [1,0,X,9,8,7,6,5,4,3,2]。
5、通过上面得知如果余数是2,就会在身份证的第18位数字上出现罗马数字的Ⅹ。如果余数是10,身份证的最后一位号码是2。
实验身份证号:‘110000198003198182’ / ‘440204199406184727’
def check_function(id_num):
if len(id_num) == 18:
# 获取前17位和最后一位
num17 = id_num[:17]
num_last = id_num[-1]
# 将前17位分别乘以不同的系数,系数是固定的
moduls = [7, 9, 10, 5, 8, 4, 2, 1, 6, 3, 7, 9, 10, 5, 8, 4, 2]
# 将前17位的字符转换成int类型
num17 = map