作者uranusjr (←这人是超级笨蛋)
看板Python
标题Re: [闲聊] 身份证产生器
时间Sat Dec 17 23:05:03 2011
※ 引述《zha0 (这个帐号是挂网用)》之铭言:
: 这二天在版上一直问一些基本的问题, 其实是要写身份证产生器(不过是某个程式的一部份)
: 以下分享写的程式码, 如果有人有兴趣, 不知可不可以再帮我把他简化 , 感谢 .
: 以前写 C 有写过不用查表的方式 , 用 if else if 一直在那里判断 A~G, H, I~... 就减多少加多少之类的 :p
: 不过觉得这样也要好几行, 还是用查表好了, 二个 array 去代入 .
: import os, sys
: from random import randint, sample, choice
: def chk():
: id=['A', 'B', 'C', 'D', 'E', 'F', 'G', 'H', 'I', 'J', 'K', 'L',
: 'M', 'N', 'O', 'P', 'Q', 'R', 'S', 'T', 'U', 'V', 'W', 'X',
: 'Y', 'Z']
: num=[10, 11, 12, 13, 14, 15, 16, 17, 34, 18, 19, 20, 21, 22, 35,
: 23, 24, 25, 26, 27, 28, 29, 32, 30, 31, 33]
: a2n=dict(zip(id, num))
为何不直接建就好了...
a2n = {'A': 10, 'B': 11, 'C': 12} #後略
其实用 C 写的话查表还更方便, 直接 alpha - 'A' 当做 index 去查就好了 :p
身分证字号的演算法不了解, 所以帮不上什麽忙
不过这部份要加速感觉效果也有限, 不如专心去做其他部分吧
: alpha = choice(id)
: r = [choice((1, 2))]+sample(range(0, 10), 7)
: k = [ v*(8-i) for i,v in enumerate(r) ]
: chk = (a2n[alpha]/10)+(a2n[alpha]%10*9) + sum(k)
: chk = (10 - (chk % 10)) % 10
: return alpha+''.join(map(str, r))+str(chk)
: if __name__ == '__main__':
: for i in range(1,10):
: print chk()
--
"问おう、贵方が私のマスターか?"
--
※ 发信站: 批踢踢实业坊(ptt.cc)
◆ From: 114.32.81.146