您的位置:首页 > 编程语言 > Python开发

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

2020-06-05 08:34 746 查看

简单的判断身份证合法性
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 = 0
for i in range(0, 17):
count = count + (int(w[i]) * int(y2[i]))
z = count % 11
m = [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 1
else:
return 0
else:
return 0

#********** End **********

#请不要修改下面的代码
if name == ‘main’:
ID_list = [
‘330702196302260412X’, ‘34052419800101001X’, ‘340524198001010011’,
‘3307021963X226041X’, ‘33070219630226041X’
]
for i in range(0, 5):
print(valid(ID_list[i]))

内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: