python实现简单验证身份证号码合法性

编程入门 行业动态 更新时间:2024-10-25 04:19:30

python实现简单验证<a href=https://www.elefans.com/category/jswz/34/1719832.html style=身份证号码合法性"/>

python实现简单验证身份证号码合法性

简单的判断身份证合法性
1.身份证前17位必须是数字
str.isdight()来判断前17位是否全是数字
2.w中保存的是前17位数字的权重分配
3.m中保存的是校验码

题目详情
一个合法的身份证号码由17位地区、生日编号和顺序编号加1位校验码(第18位)组成。
校验码的计算规则如下:
首先对前17位数字加权求和,
权重分配为:{7,9,10,5,8,4,2,1,6,3,7,9,10, 5,8,4,2};
然后将计算的和对11取模得到值Z;最后按照以下关系通过Z值获取对应的校验码M的值:
Z:0 1 2 3 4 5 6 7 8 9 10
M:1 0 X 9 8 7 6 5 4 3 2
编写函数valid判定一个身份证号码是否有效,有效则返回1,否则返回0。
例如”650402199007055298”是一个有效的身份证号,返回1;而”53072419770421191”则不是,则返回0.
实现该函数。

from math import *#请完成此函数,判定一个身份证号码是否有效,有效则返回1,否则返回0
#**********Program**********
def valid(y):y1 = y[:17]if y1.isdigit():y2 = list(y)w = [7, 9, 10, 5, 8, 4, 2, 1, 6, 3, 7, 9, 10, 5, 8, 4, 2]count = 0for i in range(0, 17):count = count + (int(w[i]) * int(y2[i]))z = count % 11m = [1, 0, "X", 9, 8, 7, 6, 5, 4, 3, 2]for i in range(0, 10):if int(i) == z:s = m[i]if str(s) == str(y[17]):return 1else:return 0else:return 0#**********  End  **********#请不要修改下面的代码
if __name__ == '__main__':ID_list = ['330702196302260412X', '34052419800101001X', '340524198001010011','3307021963X226041X', '33070219630226041X']for i in range(0, 5):print(valid(ID_list[i]))

更多推荐

python实现简单验证身份证号码合法性

本文发布于:2024-02-12 06:44:11,感谢您对本站的认可!
本文链接:https://www.elefans.com/category/jswz/34/1686657.html
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。
本文标签:身份证号码   合法性   简单   python

发布评论

评论列表 (有 0 条评论)
草根站长

>www.elefans.com

编程频道|电子爱好者 - 技术资讯及电子产品介绍!