欧美三区_成人在线免费观看视频_欧美极品少妇xxxxⅹ免费视频_a级毛片免费播放_鲁一鲁中文字幕久久_亚洲一级特黄

Python實現身份證號碼解析

系統 1622 0

中國的居民身份證有18位。其中前17位是信息碼,最后1位是校驗碼。每位信息碼可以是0-9的數字,而校驗碼可以是0-9或X,其中X表示10。

身份證校驗碼算法:

設18位身份證號序列從左到右為:
引用
a[0], a[1], a[2], a[3], ..., a[16], a[17]

其中a[i]表示第i位數字,i=0,1,2,...,17,如果最后一位(校驗位)是X,則a[17]=10

每一位被賦予一個“權值”,其中,第i位的權值w[i]的計算方法是:
引用
w[i] = 2**(17-i) % 11

其中,i=0,1,2,3,...,17,運算符按Python慣例:x**y表示x的y次方,x%y表示x除以y的余數。

如果一個身份證號是正確的,那么:
引用
(a[0]*w[0] + a[1]*w[1] + a[2]*w[2] + ... + a[16]*w[16] + a[17]*w[17]) % 11 == 1

實際上,校驗位a[17]的計算方法,就是巧妙地選擇一個值使得上式成立。

根據上述算法,下面是一個驗證身份證號正確性的程序。

初學者――――代碼沒有什么依照編寫規范,流水賬的模式。還有兩個功能沒有實現:
1、依照身份證號碼的區域代碼解析所在區域;
2、將身份證校驗碼的校驗作為前置判斷,如果錯誤就不再解析其他內容,汗,我還不會;

            
ID=input('請輸入十八位身份證號碼: ')
if len(ID)==18:
  print("你的身份證號碼是 "+ID)
else:
  print("錯誤的身份證號碼")
 
ID_add=ID[0:6]
ID_birth=ID[6:14]
ID_sex=ID[14:17]
ID_check=ID[17]
 
#ID_add是身份證中的區域代碼,如果有一個行政區劃代碼字典,就可以用獲取大致地址#
 
year=ID_birth[0:4]
moon=ID_birth[4:6]
day=ID_birth[6:8]
print("生日: "+year+'年'+moon+'月'+day+'日')
 
if int(ID_sex)%2==0:
  print('性別:女')
else:
  print('性別:男')
 
   
#此部分應為錯誤判斷,如果錯誤就不應有上面的輸出,如何實現?#
W=[7,9,10,5,8,4,2,1,6,3,7,9,10,5,8,4,2]
ID_num=[18,17,16,15,14,13,12,11,10,9,8,7,6,5,4,3,2]
ID_CHECK=['1','0','X','9','8','7','6','5','4','3','2']
ID_aXw=0
for i in range(len(W)):
  
  ID_aXw=ID_aXw+int(ID[i])*W[i]
  
ID_Check=ID_aXw%11
if ID_check==ID_CHECK[ID_Check]:
  print('正確的身份證號碼')
else:
  print('錯誤的身份證號碼')

          

我們再來看一個更加完善些的示例

            
import re
#Errors=['驗證通過!','身份證號碼位數不對!','身份證號碼出生日期超出范圍或含有非法字符!','身份證號碼校驗錯誤!','身份證地區非法!']
def checkIdcard(idcard):
  Errors=['驗證通過!','身份證號碼位數不對!','身份證號碼出生日期超出范圍或含有非法字符!','身份證號碼校驗錯誤!','身份證地區非法!']
  area={"11":"北京","12":"天津","13":"河北","14":"山西","15":"內蒙古","21":"遼寧","22":"吉林","23":"黑龍江","31":"上海","32":"江蘇","33":"浙江","34":"安徽","35":"福建","36":"江西","37":"山東","41":"河南","42":"湖北","43":"湖南","44":"廣東","45":"廣西","46":"海南","50":"重慶","51":"四川","52":"貴州","53":"云南","54":"西藏","61":"陜西","62":"甘肅","63":"青海","64":"寧夏","65":"新疆","71":"臺灣","81":"香港","82":"澳門","91":"國外"}
  idcard=str(idcard)
  idcard=idcard.strip()
  idcard_list=list(idcard)
  #地區校驗
  if(not area[(idcard)[0:2]]):
    print Errors[4]
  #15位身份號碼檢測
  if(len(idcard)==15):
    if((int(idcard[6:8])+1900) % 4 == 0 or((int(idcard[6:8])+1900) % 100 == 0 and (int(idcard[6:8])+1900) % 4 == 0 )):
      erg=re.compile('[1-9][0-9]{5}[0-9]{2}((01|03|05|07|08|10|12)(0[1-9]|[1-2][0-9]|3[0-1])|(04|06|09|11)(0[1-9]|[1-2][0-9]|30)|02(0[1-9]|[1-2][0-9]))[0-9]{3}$')#//測試出生日期的合法性
    else:
      ereg=re.compile('[1-9][0-9]{5}[0-9]{2}((01|03|05|07|08|10|12)(0[1-9]|[1-2][0-9]|3[0-1])|(04|06|09|11)(0[1-9]|[1-2][0-9]|30)|02(0[1-9]|1[0-9]|2[0-8]))[0-9]{3}$')#//測試出生日期的合法性
    if(re.match(ereg,idcard)):
      print Errors[0]
    else:
      print Errors[2]
  #18位身份號碼檢測
  elif(len(idcard)==18):
    #出生日期的合法性檢查
    #閏年月日:((01|03|05|07|08|10|12)(0[1-9]|[1-2][0-9]|3[0-1])|(04|06|09|11)(0[1-9]|[1-2][0-9]|30)|02(0[1-9]|[1-2][0-9]))
    #平年月日:((01|03|05|07|08|10|12)(0[1-9]|[1-2][0-9]|3[0-1])|(04|06|09|11)(0[1-9]|[1-2][0-9]|30)|02(0[1-9]|1[0-9]|2[0-8]))
    if(int(idcard[6:10]) % 4 == 0 or (int(idcard[6:10]) % 100 == 0 and int(idcard[6:10])%4 == 0 )):
      ereg=re.compile('[1-9][0-9]{5}19[0-9]{2}((01|03|05|07|08|10|12)(0[1-9]|[1-2][0-9]|3[0-1])|(04|06|09|11)(0[1-9]|[1-2][0-9]|30)|02(0[1-9]|[1-2][0-9]))[0-9]{3}[0-9Xx]$')#//閏年出生日期的合法性正則表達式
    else:
      ereg=re.compile('[1-9][0-9]{5}19[0-9]{2}((01|03|05|07|08|10|12)(0[1-9]|[1-2][0-9]|3[0-1])|(04|06|09|11)(0[1-9]|[1-2][0-9]|30)|02(0[1-9]|1[0-9]|2[0-8]))[0-9]{3}[0-9Xx]$')#//平年出生日期的合法性正則表達式
    #//測試出生日期的合法性
    if(re.match(ereg,idcard)):
      #//計算校驗位
      S = (int(idcard_list[0]) + int(idcard_list[10])) * 7 + (int(idcard_list[1]) + int(idcard_list[11])) * 9 + (int(idcard_list[2]) + int(idcard_list[12])) * 10 + (int(idcard_list[3]) + int(idcard_list[13])) * 5 + (int(idcard_list[4]) + int(idcard_list[14])) * 8 + (int(idcard_list[5]) + int(idcard_list[15])) * 4 + (int(idcard_list[6]) + int(idcard_list[16])) * 2 + int(idcard_list[7]) * 1 + int(idcard_list[8]) * 6 + int(idcard_list[9]) * 3
      Y = S % 11
      M = "F"
      JYM = "10X98765432"
      M = JYM[Y]#判斷校驗位
      if(M == idcard_list[17]):#檢測ID的校驗位
        print Errors[0]
      else:
        print Errors[3]
    else:
      print Errors[2]
  else:
    print Errors[1]

          

可以通過命令行輸入。第一個命令行參數是身份證號。輸出Valid或Invalid。

            
#!/usr/bin/env python 
# -*- coding: utf-8 -*- 
 
USAGE="""\ 
USAGE: python shenfenzheng.py shenfenzhenghao 
""" 
 
chmap = { 
  '0':0,'1':1,'2':2,'3':3,'4':4,'5':5,'6':6,'7':7,'8':8,'9':9, 
  'x':10,'X':10 
  } 
 
def ch_to_num(ch): 
  return chmap[ch]   
 
def verify_string(s): 
  char_list = list(s) 
  num_list = [ch_to_num(ch) for ch in char_list] 
  return verify_list(num_list) 
 
def verify_list(l): 
  sum = 0 
  for ii,n in enumerate(l): 
    i = 18-ii 
    weight = 2**(i-1) % 11 
    sum = (sum + n*weight) % 11 
     
#    print "i=%d,weight=%d,n=%d,sum=%d"%(i,weight,n,sum) 
   
#  print sum 
  return sum==1 
   
if __name__=='__main__': 
  import sys 
  if len(sys.argv)!=2: 
    print USAGE 
    sys.exit(1) 
  result = verify_string(sys.argv[1]) 
  if result: 
    print "Valid" 
  else: 
    print "Invalid" 

          

命令行使用舉例:
引用

            
$ python shenfenzheng.py 320105198209275127 

          


更多文章、技術交流、商務合作、聯系博主

微信掃碼或搜索:z360901061

微信掃一掃加我為好友

QQ號聯系: 360901061

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點擊下面給點支持吧,站長非常感激您!手機微信長按不能支付解決辦法:請將微信支付二維碼保存到相冊,切換到微信,然后點擊微信右上角掃一掃功能,選擇支付二維碼完成支付。

【本文對您有幫助就好】

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描上面二維碼支持博主2元、5元、10元、自定義金額等您想捐的金額吧,站長會非常 感謝您的哦!!!

發表我的評論
最新評論 總共0條評論
主站蜘蛛池模板: 天干夜天天夜天干天国产电影 | 久久综合狠狠色综合伊人 | 精品欧美亚洲韩国日本久久 | 黄色免费网站在线观看 | 91精品电影 | av电影直播 | 成人性生免费视频 | www.日本在线 | 成人爽a毛片免费啪啪红桃视频 | 无码免费人妻A片AAA毛片一区 | 欧美日韩在线免费观看 | 色婷婷.com | 99国产精品2018视频全部 | 国内精品视频 | 久久国产这里只精品免费 | 国产乱肥老妇国产一区二 | 激情深爱| 国产一级毛片高清视频 | 免费看a | 久草在线资源福利站 | 欧美国产日韩在线 | 国产成人精品免费午夜 | 色噜噜狠狠狠狠色综合久不 | 香蕉久 | 制服丝袜成人动漫 | 欧美色xx | 成人国产在线观看 | 91在线视频 | 天堂在线视频 | 不卡一区| 亚洲综合精品香蕉久久网97 | 国产精品久久久999 午夜免费 | 黑色丝袜美女被狂躁 | 欧洲成人综合网 | 97久久精品人人做人人爽50路 | 狠狠色丁香婷婷 | 亚洲精品久久久一区 | 97成人精品 | 亚洲精品vr一区 | 美女污视频网站 | 免费能直接在线观看黄的视频 |