一個(gè)計(jì)算身份證號(hào)碼校驗(yàn)位的Python小程序
S = Sum(Ai * Wi), i=0,.......16 (現(xiàn)在的身份證號(hào)碼都是18位長(zhǎng),其中最后一位是校驗(yàn)位,15位的身份證號(hào)碼好像不用了)
Ai對(duì)應(yīng)身份證號(hào)碼,Wi則為用于加權(quán)計(jì)算的值,它一串固定的數(shù)值,應(yīng)該是根據(jù)某種規(guī)則得出的吧,用于取得最好的隨機(jī)性,Wi的取之如下:
7 9 10 5
8 4 2 1
6 3 7 9
10 5 8 4 2
經(jīng)過(guò)加權(quán)計(jì)算之后,得到一個(gè)S,用這個(gè)S去模11,取余值,然后查表得到校驗(yàn)位,這個(gè)索引表如下:
0 ----- 1
1 ----- 0
2 ----- x
3 ----- 9
4 ----- 8
5 ----- 7
6 ----- 6
7 ----- 5
8 ----- 4
9 ----- 3
10 ----- 2
程序代碼如下:
import sys Wi = [7, 9, 10, 5, 8, 4, 2, 1, 6, 3, 7,9, 10, 5, 8, 4, 2] IndexTable = { #此處實(shí)際是無(wú)需使用字典的,使用一個(gè)包含11個(gè)元素的數(shù)組便可,數(shù)組中存放 0 : '1', #相應(yīng)位置的號(hào)碼,但是這也正好演示了Python高級(jí)數(shù)據(jù)結(jié)構(gòu)的使用 1 : '0', 2 : 'x', 3 : '9', 4 : '8', 5 : '7', 6 : '6', 7 : '5', 8 : '4', 9 : '3', 10 : '2' } No = [] sum = 0 if (len(sys.argv[1:][0]) != 17): print "error number" sys.exit() for x in sys.argv[1:][0]: No.append(x) for i in range(17): sum = sum + (int(No[i]) * Wi[i]) Index = sum % 11 print "So, your indicates parity is : %s" % (IndexTable[Index])
運(yùn)行程序方式如下:
#python getParity.py your-indentity-number-but-except-the-last-number
我的天啊,Python內(nèi)置的數(shù)據(jù)結(jié)構(gòu)是如此強(qiáng)大而易用,越來(lái)越為之而著迷啊,繼續(xù)diving~
用函數(shù)封裝一下,改進(jìn)的代碼如下:
import sys if __name__ != '__main__': print "Cannot run in module" sys.exit() Wi = [7, 9, 10, 5, 8, 4, 2, 1, 6, 3, 7,9, 10, 5, 8, 4, 2] IndexTable = { 0 : '1', 1 : '0', 2 : 'x', 3 : '9', 4 : '8', 5 : '7', 6 : '6', 7 : '5', 8 : '4', 9 : '3', 10 : '2' } def check(identity): if(len(identity) == 0): print "please input your identity number" sys.exit() elif (len(identity[0]) != 17): print "error number" sys.exit() def calculate(identity): No = [] sum = 0 for x in identity[0]: #這個(gè)方法是很笨拙的,直接使用No = list(identity[0])便可達(dá)到同樣的目的 No.append(x) for i in range(17): sum = sum + (int(No[i]) * Wi[i]) Index = sum % 11 return IndexTable[Index] check(sys.argv[1:]) result = calculate(sys.argv[1:]) print "So, your indicates parity is : %s" % (result)
忘記函數(shù)原型吧,這里不需要指明返回值類型,不需要指明形參數(shù)據(jù)類型。
相關(guān)文章
Flask與SMTP協(xié)議郵件擴(kuò)展問(wèn)題
這篇文章主要介紹了Flask與SMTP協(xié)議郵件擴(kuò)展問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-12-12Python中類方法@classmethod和靜態(tài)方法@staticmethod解析
這篇文章主要介紹了Python中類方法@classmethod和靜態(tài)方法@staticmethod解析,python中存在三種方法,分別為常規(guī)方法(定義中傳入self)、@classmethod修飾的類方法、@staticmethod修飾的靜態(tài)方法,,需要的朋友可以參考下2023-08-08pyscript的簡(jiǎn)單應(yīng)用實(shí)現(xiàn)
本文主要介紹了pyscript的簡(jiǎn)單應(yīng)用,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2022-05-05Python多進(jìn)程協(xié)作模擬實(shí)現(xiàn)流程
當(dāng)多個(gè)進(jìn)程使用同一份數(shù)據(jù)資源的時(shí)候,因?yàn)檫M(jìn)程的運(yùn)行沒(méi)有順序,運(yùn)行起來(lái)也無(wú)法控制,如果不加以干預(yù),往往會(huì)引發(fā)數(shù)據(jù)安全或順序混亂的問(wèn)題,所以要在多個(gè)進(jìn)程讀寫共享數(shù)據(jù)資源的時(shí)候加以適當(dāng)?shù)牟呗裕瑏?lái)保證數(shù)據(jù)的一致性問(wèn)題2023-01-01Django如何在不停機(jī)的情況下創(chuàng)建索引
在本篇內(nèi)容里小編給大家整理的是關(guān)于Django如何在不停機(jī)的情況下創(chuàng)建索引的相關(guān)文章,有興趣的朋友們參考學(xué)習(xí)下。2020-08-08利用 Python ElementTree 生成 xml的實(shí)例
這篇文章主要介紹了利用 Python ElementTree 生成 xml的實(shí)例,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2020-03-03Python?3.11.0下載安裝并使用help查看模塊信息的方法
本文給大家介紹Python?3.11.0下載安裝并使用help查看模塊信息的相關(guān)知識(shí),首先給大家講解了Python?3.11.0下載及安裝緊接著介紹了在命令行使用help查看模塊信息的方法,感興趣的朋友跟隨小編一起看看吧2022-11-11