设为首页 收藏本站
查看: 2892|回复: 0

[经验分享] 身份证号码自动生成程序(Python)

[复制链接]

尚未签到

发表于 2015-4-20 10:30:59 | 显示全部楼层 |阅读模式
   今天收到一个小需求:需要一个自动生成身份证号码的小程序。近期用python较多,因此打算用python实现。
  
  需求细化
  1.身份证必须能够通过身份证校验程序。
  2.通过查询,发现身份证号码是有国家标准的,标准号为  GB 11643-1999  可以从百度下载到这个文档http://zhidao.baidu.com/share/b838c7683bb70af8166efd810a398fec.html
  现行身份证号为18位,分别为6位地址码,8位生日,3位顺序码,一位校验码。具体例子可见下图。
DSC0000.jpg
  前六位也是国家标准,GB2260-2007。吐槽一下,国标竟然没有一个网站供全面检索和免费下载。。。还好国家统计局有这些公开数据。可以从统计数据-》统计标准-》行政区划代码页面内找到最新数据:http://www.stats.gov.cn/tjsj/tjbz/xzqhdm/201401/t20140116_501070.html (这个网页上的数据可能会边旧)
  出生年月日是8位
  顺序码是3位,男生末尾为基数,女生末尾为偶数。
  最后一位是校验码。校验算法其实后面有很多数学道理,这里给出最简单的公式:
  前17位数字每一位有一个权重值
  将第i位上的权重值记作Wi,Wi的值为 7 9 10 5 8 4 2 1 6 3 7 9 10 5 8 4 2
  将身份证第i位的数字记作Ai
  则使用下列公式算出一个数
  S= Sum(Ai*Wi)  mod 11    ------------- Sum(Ai*Wi) 取11的模。
  
  这样S的取值如下表:
  
  对每一个S做一个映射 Y,这样就有如下的表
  
  S:0  1  2  3  4  5  6  7  8  9  10
  Y:1  0  X  9  8  7  6  5  4  3  2
  Y就是最终的校验码。
  
  原型实现过程:
  1.获取区域规划码的list,并读入一个dictionary的list中。dictionary结构如下:
  {"state":河北省,"city":沧州市,"district":运河区,"code":130903}
  丑陋的原型如下:



def getdistrictcode():
with open('districtcode') as file:
data = file.read()
districtlist = data.split('\n')
global codelist
codelist = []
for node in districtlist:
#print node
if node[10:11] != ' ':
state = node[10:].strip()
if node[10:11]==' 'and node[12:13]!=' ':
city = node[12:].strip()
if node[10:11] == ' 'and  node[12:13]==' ':
district = node[14:].strip()
code = node[0:6]
codelist.append({"state":state,"city":city,"district":district,"code":code})
  上部你得到了一个codelist,里边有所有的区号了。
  下面是生成身份证号的原型,基本上是随机生成



def gennerator():
id = codelist[random.randint(0,len(codelist))]['code'] #地区项
id = id + str(random.randint(1930,2013)) #年份项
da  = date.today()+timedelta(days=random.randint(1,366)) #月份和日期项
id = id + da.strftime('%m%d')
id = id+ str(random.randint(100,300))#,顺序号简单处理

i = 0
count = 0
weight = [7, 9, 10, 5, 8, 4, 2, 1, 6, 3, 7, 9, 10, 5, 8, 4, 2] #权重项
checkcode ={'0':'1','1':'0','2':'X','3':'9','4':'8','5':'7','6':'6','7':'5','8':'5','9':'3','10':'2'} #校验码映射
for i in range(0,len(id)):
count = count +int(id)*weight
id = id + checkcode[str(count%11)] #算出校验码
return id
  
  原型用到了python的两个标准库



from datetime import date
from datetime import timedelta
  
这样就能初步满足需要了,后续可以根据要就对工具进行细化。
  btw,其实,正在开发一个测试数据生成的工具集,近期争取开源。有任何具体需求可以提给我。有想一起做的同学也大大的欢迎:)
  

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-58709-1-1.html 上篇帖子: 我也要学python-内置数据结构(一) 下篇帖子: [python01] python列表,元组对比Erlang的区别总结
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表