CPF and CNPJ validation and generation with support for alphanumeric CNPJ
Project description
📦 br-cpf-cnpj
A Python library for CPF and CNPJ validation and generation, with support for the new alphanumeric CNPJ standard.
✨ Features
- ✅ CPF validation
- ✅ CNPJ validation (numeric and alphanumeric)
- 🔢 Random CPF generator
- 🔡 Random CNPJ generator (numeric or alphanumeric)
- 🧪 Fully tested with pytest
📥 Installation
pip install br-cpf-cnpj
🚀 Usage
Validate CPF
from br_cpf_cnpj import is_valid_cpf
is_valid_cpf("529.982.247-25")
# True
# Validate unmasked CPF
is_valid_cpf("55782724366")
# True
# Validate numeric CPF
is_valid_cpf(70714720178)
# True
NOTE: If the value is a number, it will be converted to a string and any leading zeros will be removed.
Validate CNPJ
from br_cpf_cnpj import is_valid_cnpj
# Validate numeric CNPJ
is_valid_cnpj("11.222.333/0001-81")
# True
# Validate alphanumeric CNPJ
is_valid_cnpj("2P.76B.MNX/0001-66")
# True
# Validate unmasked CNPJ
is_valid_cnpj("B4ESBMHS000102")
# True
Generate Random CPF
from br_cpf_cnpj import generate_random_cpf
cpf = generate_random_cpf(masked=True)
print(cpf)
# e.g., "123.456.789-09"
cpf_unmasked = generate_random_cpf(masked=False)
print(cpf_unmasked)
# e.g., "12345678909"
Generate Random CNPJ
from br_cpf_cnpj import generate_random_cnpj
# Generate numeric CNPJ
cnpj_numeric = generate_random_cnpj(alphanumeric=False, masked=True)
print(cnpj_numeric)
# e.g., "12.345.678/0001-95"
# Generate alphanumeric CNPJ
cnpj_alphanumeric = generate_random_cnpj(alphanumeric=True, masked=False)
print(cnpj_alphanumeric)
# e.g., "RSASKDDW000100"
🧠 How it works
CPF
- Uses fixed weights (10 → 2, then 11 → 2)
- Applies the official modulo 11 algorithm
- Prevents invalid repeated-digit CPFs (e.g.
11111111111)
CNPJ (Alphanumeric)
- Supports digits (0–9) and uppercase letters (A–Z)
- Characters are converted using:
value = ord(char) - ord('0') - Weights cycle from 2 → 9
🤝 Contributing
Contributions are very welcome!
Development Setup
This project uses uv for dependency management. To set up your development environment:
- Clone the repository
- Install dependencies:
uv sync --extra dev - Run tests:
uv run pytest
📄 License
MIT License.
Versão em Português
📦 br-cpf-cnpj
Uma biblioteca Python para validação e geração de CPF e CNPJ, com suporte ao novo padrão de CNPJ alfanumérico.
✨ Funcionalidades
- ✅ Validação de CPF
- ✅ Validação de CNPJ (numérico e alfanumérico)
- 🔢 Gerador de CPF aleatório
- 🔡 Gerador de CNPJ aleatório (numérico ou alfanumérico)
- 🧪 Testes automatizados com pytest
📥 Instalação
pip install br-cpf-cnpj
🚀 Uso
Validar CPF
from br_cpf_cnpj import is_valid_cpf
is_valid_cpf("529.982.247-25")
# True
# Validar CPF sem máscara
is_valid_cpf("55782724366")
# True
# Validar CPF numérico
is_valid_cpf(70714720178)
# True
NOTA: Se o valor for um número, ele será convertido para string e quaisquer zeros à esquerda serão removidos.
Validar CNPJ
from br_cpf_cnpj import is_valid_cnpj
# Validar CNPJ numérico
is_valid_cnpj("11.222.333/0001-81")
# True
# Validar CNPJ alfanumérico
is_valid_cnpj("2P.76B.MNX/0001-66")
# True
# Validar CNPJ sem máscara
is_valid_cnpj("B4ESBMHS000102")
# True
Gerar CPF Aleatório
from br_cpf_cnpj import generate_random_cpf
cpf = generate_random_cpf(masked=True)
print(cpf)
# e.g., "123.456.789-09"
cpf_unmasked = generate_random_cpf(masked=False)
print(cpf_unmasked)
# e.g., "12345678909"
Gerar CNPJ Aleatório
from br_cpf_cnpj import generate_random_cnpj
# Gerar CNPJ numérico
cnpj_numeric = generate_random_cnpj(alphanumeric=False, masked=True)
print(cnpj_numeric)
# e.g., "12.345.678/0001-95"
# Gerar CNPJ alfanumérico
cnpj_alphanumeric = generate_random_cnpj(alphanumeric=True, masked=False)
print(cnpj_alphanumeric)
# e.g., "RSASKDDW000100"
🧠 Como Funciona
CPF
- Pesos fixos (10 → 2 e 11 → 2)
- Algoritmo módulo 11
- Rejeita CPFs inválidos com dígitos repetidos (e.g.
11111111111)
CNPJ (Alfanumérico)
- Aceita números (0–9) e letras (A–Z)
- Conversão baseada em valor ASCII:
value = ord(char) - ord('0') - Pesos cíclicos de 2 → 9
🤝 Contribuindo
Contribuições são muito bem-vindas!
Configuração do Ambiente de Desenvolvimento
Este projeto utiliza uv para gerenciamento de dependências. Para configurar seu ambiente de desenvolvimento:
- Clone o repositório
- Instale as dependências:
uv sync --extra dev - Execute os testes:
uv run pytest
📄 License
MIT License.
Project details
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file br_cpf_cnpj-0.2.0.tar.gz.
File metadata
- Download URL: br_cpf_cnpj-0.2.0.tar.gz
- Upload date:
- Size: 4.4 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: uv/0.10.4 {"installer":{"name":"uv","version":"0.10.4","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Ubuntu","version":"24.04","id":"noble","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":null}
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
bfca8fac36e15381f8ed840331a88e970ee556555438bfc9b6b1121e3add6397
|
|
| MD5 |
302e1982bf7cafb020777a04c5b49475
|
|
| BLAKE2b-256 |
dfc4f57aecbdf4b47d2d1bab6a14154209824cd8585280e6460cbbbfe0bccfd9
|
File details
Details for the file br_cpf_cnpj-0.2.0-py3-none-any.whl.
File metadata
- Download URL: br_cpf_cnpj-0.2.0-py3-none-any.whl
- Upload date:
- Size: 6.0 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: uv/0.10.4 {"installer":{"name":"uv","version":"0.10.4","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Ubuntu","version":"24.04","id":"noble","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":null}
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
3f0c43ff7f79c4e47d38978af42445f26970de15bc5a8438d1e513bb34fd6ccc
|
|
| MD5 |
67cddbbffe82288e0f5f8f3474a32acd
|
|
| BLAKE2b-256 |
0b6eca54ad9d8079d8ec34fccccb763a6449db35e9544159f914d74fca91c67f
|