Pacote Python para validação de documentos brasileiros.
Para instalar o pacote:
pip install validate-docbrOu com uv:
uv add validate-docbrA documentação pode ser acessada clicando aqui.
Documentos que estão no pacote:
- CPF: Cadastro de Pessoas Físicas;
- CNH: Carteira Nacional de Habilitação;
- CNPJ: Cadastro Nacional da Pessoa Jurídica (numérico e alfanumérico);
- CNS: Cartão Nacional de Saúde;
- PIS: PIS/NIS/PASEP/NIT;
- Título eleitoral: Cadastro que permite cidadãos brasileiros votar;
- RENAVAM: Registro Nacional de Veículos Automotores;
- Certidão: Certidão de Nascimento/Casamento/Óbito.
Para entender melhor os documentos e suas respectivas classes, basta acessar a Wiki do projeto.
Todos os documentos possuem os mesmos métodos e funcionam da mesma forma.
Valida o documento passado como argumento. Retorna um bool,
True caso seja válido, False caso contrário.
Recebe os parâmetros:
| Parâmetro | Tipo | Valor padrão | Obrigatório | Descrição |
|---|---|---|---|---|
doc |
str |
'' |
X | Documento a validar. |
from validate_docbr import CPF
cpf = CPF()
# Validar CPF
cpf.validate("012.345.678-90") # True
cpf.validate("012.345.678-91") # FalseValida uma lista de documentos passado como argumento.
Retorna uma lista de bool, True caso seja válido,
False caso contrário. Recebe os parâmetros:
| Parâmetro | Tipo | Valor padrão | Obrigatório | Descrição |
|---|---|---|---|---|
docs |
list[str] |
[] |
X | Lista de docs. |
from validate_docbr import CPF
cpf = CPF()
# Validar CPFs
cpf.validate_list(["012.345.678-90", "012.345.678-91"])
# [True, False]Observação: diferente dos outros métodos, esse método é do escopo global do pacote, não precisa-se instanciar uma classe para uso.
Valida vários documentos diferentes. Retorna uma lista com
valores bool para cada tupla da lista (na mesma ordem),
True caso seja válido, False caso contrário.
Recebe os parâmetros:
| Parâmetro | Tipo | Obrigatório | Descrição |
|---|---|---|---|
documents |
list[tuple[...]] |
X | Lista de tuplas. |
Cada tupla possui como primeiro elemento o tipo de documento
(DocumentBase) e o segundo o valor que se deseja validar.
import validate_docbr as docbr
# Validar diferentes documentos
docs = [
(docbr.CPF, '90396100457'),
(docbr.CNPJ, '49910753848365'),
]
docbr.validate_docs(docs) # [True, False]Gera um novo documento, retorna em formato de str.
Recebe os parâmetros:
| Parâmetro | Tipo | Valor padrão | Obrigatório | Descrição |
|---|---|---|---|---|
mask |
bool |
False |
- | Retorna com máscara. |
from validate_docbr import CPF
cpf = CPF()
# Gerar novo CPF
new_cpf_one = cpf.generate() # "01234567890"
new_cpf_two = cpf.generate(mask=True) # "012.345.678-90"Gera uma lista de documentos, retorna em formato de list
com elementos do tipo str. Recebe os parâmetros:
| Parâmetro | Tipo | Valor padrão | Obrigatório | Descrição |
|---|---|---|---|---|
n |
int |
1 |
X | Quantidade. |
mask |
bool |
False |
- | Com máscara. |
repeat |
bool |
False |
- | Aceita repetidos. |
from validate_docbr import CPF
cpf = CPF()
# Gerar lista de CPFs
cpfs_one = cpf.generate_list(2)
# [ "85215667438", "28293145811" ]
cpfs_two = cpf.generate_list(2, mask=True)
# [ "852.156.674-38", "282.931.458-11" ]Mascara o documento passado como argumento. Retorna um str
que é o documento mascarado. Aceita documentos com ou sem
pontuação. Recebe os parâmetros:
| Parâmetro | Tipo | Valor padrão | Obrigatório | Descrição |
|---|---|---|---|---|
doc |
str |
'' |
X | Documento a mascarar. |
from validate_docbr import CPF
cpf = CPF()
cpf_me = "01234567890"
# Mascara o CPF
cpf.mask(cpf_me) # "012.345.678-90"Para realizar os testes basta executar o seguinte comando:
task testPara verificar a cobertura de testes:
task test-coveragePara verificar os tipos:
task type-check