Re: [閒聊] 身份證產生器
※ 引述《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
討論串 (同標題文章)
Python 近期熱門文章
PTT數位生活區 即時熱門文章