Possíveis problemas e soluções para nosso algoritmo do CPF
This commit is contained in:
73
aula63.py
Normal file
73
aula63.py
Normal file
@@ -0,0 +1,73 @@
|
|||||||
|
"""
|
||||||
|
Calculo do segundo dígito do CPF
|
||||||
|
CPF: 746.824.890-70
|
||||||
|
Colete a soma dos 9 primeiros dígitos do CPF,
|
||||||
|
MAIS O PRIMEIRO DIGITO,
|
||||||
|
multiplicando cada um dos valores por uma
|
||||||
|
contagem regressiva começando de 11
|
||||||
|
|
||||||
|
Ex.: 746.824.890-70 (7468248907)
|
||||||
|
11 10 9 8 7 6 5 4 3 2
|
||||||
|
* 7 4 6 8 2 4 8 9 0 7 <-- PRIMEIRO DIGITO
|
||||||
|
77 40 54 64 14 24 40 36 0 14
|
||||||
|
|
||||||
|
Somar todos os resultados:
|
||||||
|
77+40+54+64+14+24+40+36+0+14 = 363
|
||||||
|
Multiplicar o resultado anterior por 10
|
||||||
|
363 * 10 = 3630
|
||||||
|
Obter o resto da divisão da conta anterior por 11
|
||||||
|
3630 % 11 = 0
|
||||||
|
Se o resultado anterior for maior que 9:
|
||||||
|
resultado é 0
|
||||||
|
contrário disso:
|
||||||
|
resultado é o valor da conta
|
||||||
|
|
||||||
|
O segundo dígito do CPF é 0
|
||||||
|
"""
|
||||||
|
# cpf = '36440847007' # Esse CPF gera o primeiro dígito como 10 (0)
|
||||||
|
import re
|
||||||
|
import sys
|
||||||
|
|
||||||
|
# cpf_enviado_usuario = '746.824.890-70' \
|
||||||
|
# .replace('.', '') \
|
||||||
|
# .replace(' ', '') \
|
||||||
|
# .replace('-', '')
|
||||||
|
entrada = input('CPF [746.824.890-70]: ')
|
||||||
|
cpf_enviado_usuario = re.sub(
|
||||||
|
r'[^0-9]',
|
||||||
|
'',
|
||||||
|
entrada
|
||||||
|
)
|
||||||
|
|
||||||
|
entrada_e_sequencial = entrada == entrada[0] * len(entrada)
|
||||||
|
|
||||||
|
if entrada_e_sequencial:
|
||||||
|
print('Você enviou dados sequenciais.')
|
||||||
|
sys.exit()
|
||||||
|
|
||||||
|
nove_digitos = cpf_enviado_usuario[:9]
|
||||||
|
contador_regressivo_1 = 10
|
||||||
|
|
||||||
|
resultado_digito_1 = 0
|
||||||
|
for digito in nove_digitos:
|
||||||
|
resultado_digito_1 += int(digito) * contador_regressivo_1
|
||||||
|
contador_regressivo_1 -= 1
|
||||||
|
digito_1 = (resultado_digito_1 * 10) % 11
|
||||||
|
digito_1 = digito_1 if digito_1 <= 9 else 0
|
||||||
|
|
||||||
|
dez_digitos = nove_digitos + str(digito_1)
|
||||||
|
contador_regressivo_2 = 11
|
||||||
|
|
||||||
|
resultado_digito_2 = 0
|
||||||
|
for digito in dez_digitos:
|
||||||
|
resultado_digito_2 += int(digito) * contador_regressivo_2
|
||||||
|
contador_regressivo_2 -= 1
|
||||||
|
digito_2 = (resultado_digito_2 * 10) % 11
|
||||||
|
digito_2 = digito_2 if digito_2 <= 9 else 0
|
||||||
|
|
||||||
|
cpf_gerado_pelo_calculo = f'{nove_digitos}{digito_1}{digito_2}'
|
||||||
|
|
||||||
|
if cpf_enviado_usuario == cpf_gerado_pelo_calculo:
|
||||||
|
print(f'{cpf_enviado_usuario} é válido')
|
||||||
|
else:
|
||||||
|
print('CPF inválido')
|
||||||
Reference in New Issue
Block a user