S = Sum(Ai * Wi), i=0,.......16 (現在的身份證號碼都是18位長,其中最后一位是校驗位,15位的身份證號碼好像不用了)
Ai對應身份證號碼,Wi則為用于加權計算的值,它一串固定的數值,應該是根據某種規則得出的吧,用于取得最好的隨機性,Wi的取之如下:
7?? 9 10 5
8?? 4?? 2?? 1
6?? 3?? 7?? 9
10? 5?? 8?? 4?? 2
經過加權計算之后,得到一個S,用這個S去模11,取余值,然后查表得到校驗位,這個索引表如下:
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 = { #此處實際是無需使用字典的,使用一個包含11個元素的數組便可,數組中存放
0 : '1', #相應位置的號碼,但是這也正好演示了Python高級數據結構的使用
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])
運行程序方式如下:
#python getParity.py your-indentity-number-but-except-the-last-number
我的天啊,Python內置的數據結構是如此強大而易用,越來越為之而著迷啊,繼續diving~
用函數封裝一下,改進的代碼如下:
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]: #這個方法是很笨拙的,直接使用No = list(identity[0])便可達到同樣的目的
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)
忘記函數原型吧,這里不需要指明返回值類型,不需要指明形參數據類型。
更多文章、技術交流、商務合作、聯系博主
微信掃碼或搜索:z360901061
微信掃一掃加我為好友
QQ號聯系: 360901061
您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點擊下面給點支持吧,站長非常感激您!手機微信長按不能支付解決辦法:請將微信支付二維碼保存到相冊,切換到微信,然后點擊微信右上角掃一掃功能,選擇支付二維碼完成支付。
【本文對您有幫助就好】元

