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

看板Python作者 (沒)時間14年前 (2011/12/21 18:05), 編輯推噓0(002)
留言2則, 2人參與, 最新討論串4/4 (看更多)
---------%<-----------%<---------------------------------------------------- #!/usr/bin/python import re i = raw_input('input: '); i = i.capitalize() if not re.match('^[A-Z][12][0-9]{8}$', i): print 'pattern not valid'; exit() a = []; a.extend("10987654932210898765431320") c = int(a[ord(i[0])-65]) + int(i[9]) for x in range(1, 9): c += int(i[x]) * (9 - x) if c % 10 != 0: print 'rule check failed'; exit() print 'pass' -------->%----------->%----------------------------------------------------- 分享一下我的寫法,大致上跟[darkgerm]分享的差不多,也是先計算英文字母 不過我選擇使用一般語法去寫,避開進階語法操作,額外補上pattern檢查 原則上就是... 既然有固定格式,那麼可以把能做的先做,減少計算 1. 請求輸入後,將首字轉為大寫字母(方便第四個步驟處理) 2. 利用regular expression做簡易判斷,若不符合規則,那就不用繼續做下去了 3. 公式是固定的,可以先建表,如 C 12 => ((12/10)+(12%10)*9)%10 = 9 Z 33 => ((33/10)+(33%10)*9)%10 = 0 [ABCDEFGHIJKLMNOPQRSTUVWXYZ] [10987654932210898765431320] ^^^^^^^^^^^^^^^^^^^^^^^^^^^^ 先把 A-Z 對應數值查表套入公式計算所得 4. 先處理(首字轉換、檢查碼) 5. 再處理(剩餘數值) 6. 判斷是否整除 參考看看 :) ※ 引述《darkgerm (黑駿)》之銘言: : 事實上,"對照"這件事是可以事先化簡的 : ("英文部分" + "流水號部分" + "檢查碼") %10 = 0 : ("英文部分"%10 + "流水號部分" + "檢查碼") %10 = 0 : 這兩個意思一樣 : 於是我可以把 10 11 12... 先"十位加個位" %10 (身分證計算法) : 然後就能寫成字串 "10987654932210898765431320" : 這是我的寫法: : alpha = choice(range(26)) : ret = [choice([1,2])] + sample(range(10),7) : chk = [ v*(8-i) for i,v in enumerate(ret) ] : chk = int("10987654932210898765431320"[alpha]) + sum(chk) : chk = (10-chk%10) % 10 : return chr(alpha+ord("A")) + ''.join(map(str,ret)) + str(chk) : 其實 chk 是可以全部縮成一行的XD 不過那樣會變得很醜就是了 : (如何在最短行數做到最多的事是我樂趣之一XD) -- guessiguess█▇▇▇ iguessiguessig▁▂▂▁uessiguessiguessigues by kizna guessi▇▇▇ guessiguessigY kizna Yuessiguessiguessiguessiguess guessigues█▓█ siguessiguessζζiguessiguessiguessiguessigue gues◢█◣s████ iguessiguess ig他們是我的銅板(同伴)!uess gues█◥siguessiguessig uessiguessiguessiguessiguess guessi gues◥██ siguessiguessi guessiguessiguessiguessiguess -- ※ 發信站: 批踢踢實業坊(ptt.cc) ◆ From: 134.208.3.21 標個顏色方便閱讀 :) ※ 編輯: guessi 來自: 134.208.3.21 (12/21 18:10)

12/21 21:54, , 1F
原原po是要做產生器,你寫成檢查器了XD
12/21 21:54, 1F

12/22 02:15, , 2F
啊... 搞笑了XD 沒關係 反向思考就好 這篇就當參考吧 XD
12/22 02:15, 2F
文章代碼(AID): #1EyQzqeP (Python)
文章代碼(AID): #1EyQzqeP (Python)