身份证号的尾数校验

在先前数据模拟一文中,我们谈到了身份证号的尾数校验。

身份证尾数就是第十八位数的校验码。计算方法是将身份证前十七位数分别乘以不同系数,7、9、10、5、8、4、2、1、6、3、7、9、10、5、8、4、2,再把相乘的结果相加,和除以11,看看余数是多少。余数只可能有0、1、2、3、4、5、6、7、8、9、10这十一个数字,其分别对应的最后一位身份证的号码为1、0、X、9、8、7、6、5、4、3、2,这样就得出了第二代身份证第十八位数的校验码。

不过当时为了生成数据的简便性,并没有用上,而是采取了随机。现在就把它完善下,用的是上次生成的身份证号数据。
在这里插入图片描述
大致思路就是,提取原身份证号的前17位数,并逐个拆分。比如上面的32万条数据,可拆成一个320000 X 17的矩阵。然后利用矩阵乘法,按上面校验位的定义进行计算,求余数,再换成对应的字符,最后和原来的前17位拼接起来,形成最新且正确的身份证号码。
在这里插入图片描述
在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值