python 对身份证号码的正则判断

python 对身份证号码的正则判断

def is_valid_id_card(id_card):
    ''' 校验是否为正确的身份证号码 '''
    pattern = '[1-9][0-9]{14}([0-9]{2}[0-9X])?'
    if isinstance(id_card, int):
        id_card = str(id_card)

    if not re.match(pattern, id_card):
        return False
    items = [int(item) for item in id_card[:-1]]
    # 加权因子表
    factors = (7, 9, 10, 5, 8, 4, 2, 1, 6, 3, 7, 9, 10, 5, 8, 4, 2)
    # 计算17位数字各位数字与对应的加权因子的乘积
    copulas = sum([a * b for a, b in zip(factors, items)])
    # 校验码表
    ck_codes = ('1', '0', 'X', '9', '8', '7', '6', '5', '4', '3', '2')
    a = ck_codes[copulas % 11].upper()
    b = id_card[-1].upper()
    return a == b



            
            

本博客源码Github地址:

https://github.com/whisnos/myblog

请随手给个star,谢谢!

打赏

评论