求在Excel中使用的身份证校验代码!谢谢!
求Python代码,用途是校验Excel单元格中身份证号是否合法,及其归属地等信息。 立即校验吗 还是事后统一校验 是事后一起校验。例如:某工作表,A1:A1000,一共有1000个身份证号,通过python验证,在B2:B1000中分别填入合法或者不合法,如果不合法最好还能标注原因。 victoryer 发表于 2021-3-18 14:42是事后一起校验。例如:某工作表,A1:A1000,一共有1000个身份证号,通过python验证,在B2:B1000中分别填入 ...
网上搜一下,身份证的个个字段的意义
不知道最后一位校验码是咋算的 六位数字地址码,也就是归属地,八位数字出生日期码,三位数字顺序码和一位数字校验码
第十七位奇数是男性,偶数是女性、
第十八位计算方法
----------
计算方法
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。(即余数0对应1,余数1对应0,余数2对应X...)
5、通过上面得知如果余数是3,就会在身份证的第18位数字上出现的是9。如果对应的数字是2,身份证的最后一位号码就是罗马数字X。
例如:某男性的身份证号码为【53010219200508011X】, 我们看看这个身份证是不是符合计算规则的身份证。
首先我们得出前17位的乘积和【(5*7)+(3*9)+(0*10)+(1*5)+(0*8)+(2*4)+(1*2)+(9*1)+(2*6)+(0*3)+(0*7)+(5*9)+(0*10)+(8*5)+(0*8)+(1*4)+(1*2)】是189,然后用189除以11得出的结果是189÷11=17余下2,187÷11=17,还剩下2不能被除尽,也就是说其余数是2。最后通过对应规则就可以知道余数2对应的检验码是X。所以,可以判定这是一个正确的身份证号码。
页:
[1]