Re: [閒聊] 身份證產生器

看板Python作者 (←這人是超級笨蛋)時間14年前 (2011/12/17 23:05), 編輯推噓0(000)
留言0則, 0人參與, 最新討論串3/4 (看更多)
※ 引述《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
文章代碼(AID): #1ExA-XSf (Python)
文章代碼(AID): #1ExA-XSf (Python)