Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/brazilian-utils/brutils-python
Biblioteca de utilitários projetada para validar, gerar e manipular dados de acordo com as particularidades do Brasil 🇧🇷
https://github.com/brazilian-utils/brutils-python
brazil cnpj cpf email hacktoberfest pip pis placa-de-carro processo-juridico python tituloeleitor validation
Last synced: 2 months ago
JSON representation
Biblioteca de utilitários projetada para validar, gerar e manipular dados de acordo com as particularidades do Brasil 🇧🇷
- Host: GitHub
- URL: https://github.com/brazilian-utils/brutils-python
- Owner: brazilian-utils
- License: mit
- Created: 2017-01-10T06:52:22.000Z (about 8 years ago)
- Default Branch: main
- Last Pushed: 2024-10-21T14:12:58.000Z (3 months ago)
- Last Synced: 2024-10-21T23:25:13.313Z (3 months ago)
- Topics: brazil, cnpj, cpf, email, hacktoberfest, pip, pis, placa-de-carro, processo-juridico, python, tituloeleitor, validation
- Language: Python
- Homepage: https://pypi.python.org/pypi/brutils
- Size: 483 KB
- Stars: 236
- Watchers: 7
- Forks: 55
- Open Issues: 29
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- Contributing: CONTRIBUTING.md
- Funding: .github/FUNDING.yml
- License: LICENSE
- Code of conduct: CODE_OF_CONDUCT.md
- Codeowners: .github/CODEOWNERS
Awesome Lists containing this project
README
🇧🇷 Brazilian Utils
Utils library for Brazilian-specific businesses.
[![codecov](https://codecov.io/gh/brazilian-utils/brutils-python/branch/main/graph/badge.svg?token=5KNECS8JYF)](https://codecov.io/gh/brazilian-utils/brutils-python)
[![Downloads per Month](https://shields.io/pypi/dm/brutils)](https://pypistats.org/packages/brutils)
[![Package version](https://shields.io/pypi/v/brutils)](https://pypi.org/project/brutils/)### [Looking for the english version?](README_EN.md)
# Introdução
Brazilian Utils é uma biblioteca com foco na resolução de problemas que enfrentamos diariamente no
desenvolvimento de aplicações para o business Brasileiro.- [Instalação](#instalação)
- [Utilização](#utilização)
- [Utilitários](#utilitários)
- [Novos Utilitários e Reportar Bugs](#novos-utilitários-e-reportar-bugs)
- [Dúvidas? Ideias?](#dúvidas-ideias)
- [Contribuindo com o Código do Projeto](#contribuindo-com-o-código-do-projeto)# Instalação
```bash
pip install brutils
```# Utilização
Para usar um de nossos utilitários, basta importar a função necessária, como no exemplo abaixo:
```python
>>> from brutils import is_valid_cpf
>>> is_valid_cpf('00011122233')
False
```# Utilitários
- [CPF](#cpf)
- [is\_valid\_cpf](#is_valid_cpf)
- [format\_cpf](#format_cpf)
- [remove\_symbols\_cpf](#remove_symbols_cpf)
- [generate\_cpf](#generate_cpf)
- [CNPJ](#cnpj)
- [is\_valid\_cnpj](#is_valid_cnpj)
- [format\_cnpj](#format_cnpj)
- [remove\_symbols\_cnpj](#remove_symbols_cnpj)
- [generate\_cnpj](#generate_cnpj)
- [CEP](#cep)
- [is\_valid\_cep](#is_valid_cep)
- [format\_cep](#format_cep)
- [remove\_symbols\_cep](#remove_symbols_cep)
- [generate\_cep](#generate_cep)
- [get\_address\_from\_cep](#get_address_from_cep)
- [get\_cep\_information\_from\_address](#get_cep_information_from_address)
- [Telefone](#telefone)
- [is\_valid\_phone](#is_valid_phone)
- [format\_phone](#format_phone)
- [remove\_symbols\_phone](#remove_symbols_phone)
- [remove\_international\_dialing\_code](#remove_international_dialing_code)
- [generate\_phone](#generate_phone)
- [Email](#email)
- [is\_valid\_email](#is_valid_email)
- [Placa de Carro](#placa-de-carro)
- [is\_valid\_license\_plate](#is_valid_license_plate)
- [format\_license\_plate](#format_license_plate)
- [remove\_symbols\_license\_plate](#remove_symbols_license_plate)
- [generate\_license\_plate](#generate_license_plate)
- [convert\_license\_plate\_to\_mercosul](#convert_license_plate_to_mercosul)
- [get\_format\_license\_plate](#get_format_license_plate)
- [PIS](#pis)
- [is\_valid\_pis](#is_valid_pis)
- [format\_pis](#format_pis)
- [remove\_symbols\_pis](#remove_symbols_pis)
- [generate\_pis](#generate_pis)
- [Processo JurÃdico](#processo-jurÃdico)
- [is\_valid\_legal\_process](#is_valid_legal_process)
- [format\_legal\_process](#format_legal_process)
- [remove\_symbols\_legal\_process](#remove_symbols_legal_process)
- [generate\_legal\_process](#generate_legal_process)
- [TÃtulo Eleitoral](#titulo-eleitoral)
- [is_valid_voter_id](#is_valid_voter_id)
- [format_voter_id](#format_voter_id)
- [generate_voter_id](#generate_voter_id)
- [IBGE](#ibge)
- [convert_code_to_uf](#convert_code_to_uf)## CPF
### is_valid_cpf
Retorna se os dÃgitos de verificação do CPF fornecido
correspondem ao seu número base. Esta função não verifica a existência do CPF;
ela apenas valida o formato da string.Argumentos:
- cpf (str): O CPF a ser validado, uma string de 11 dÃgitos
Retorna:
- bool: Verdadeiro se os dÃgitos de verificação corresponderem ao número base,
Falso caso contrário.Exemplo:
```python
>>> from brutils import is_valid_cpf
>>> is_valid_cpf("82178537464")
True
>>> is_valid_cpf('00011122233')
False
```### format_cpf
Formata um CPF (Cadastro de Pessoa FÃsica brasileiro) para exibição visual.
Esta função recebe uma string de CPF contendo apenas números como entrada e
adiciona sÃmbolos de formatação padrão para exibição.Argumentos:
- cpf (str): Uma string de CPF contendo apenas números.
Retorna:
- str: O CPF formatado com sÃmbolos visuais se for válido,
None se não for válido.Exemplo:
```python
>>> from brutils import format_cpf
>>> format_cpf('82178537464')
'821.785.374-64'
>>> format_cpf("55550207753")
'555.502.077-53'
```### remove_symbols_cpf
Remove sÃmbolos especÃficos de uma string de CPF (Cadastro de Pessoa FÃsica
brasileiro). Esta função recebe como entrada uma string de CPF e remove todas as
ocorrências dos caracteres '.', '-' dela.Argumentos:
- cpf (str): A string de CPF contendo os sÃmbolos a serem removidos.
Retorna:
- str: Uma nova string com os sÃmbolos especificados removidos.
Exemplo:
```python
>>> from brutils import remove_symbols_cpf
>>> remove_symbols_cpf('000.111.222-33')
'00011122233'
```### generate_cpf
Gerar uma string de dÃgitos de CPF válida aleatória.
Retorna:
- str: Um CPF válido gerado aleatoriamente.
Exemplo:
```python
>>> from brutils import generate_cpf
>>> generate_cpf()
'17433964657'
>>> generate_cpf()
"10895948109"
```## CNPJ
### is_valid_cnpj
Verifica se os dÃgitos de verificação do CNPJ (Cadastro Nacional da Pessoa
JurÃdica) fornecido correspondem ao seu número base. A entrada deve ser uma
string de dÃgitos com o comprimento apropriado. Esta função não verifica a
existência do CNPJ; ela só valida o formato da string.Argumentos:
- cnpj (str): O CNPJ a ser validado.
Retorna:
- bool: True se os dÃgitos de verificação corresponderem ao número base,
False caso contrário.Exemplo:
```python
>>> from brutils import is_valid_cnpj
>>> is_valid_cnpj('03560714000142')
True
>>> is_valid_cnpj('00111222000133')
False
```### format_cnpj
Formata uma string de CNPJ (Cadastro Nacional da Pessoa JurÃdica) para exibição
visual.
Esta função recebe uma string de CNPJ como entrada, valida seu formato e a
formata com sÃmbolos visuais padrão para fins de exibição.Argumentos:
- cnpj (str): A string de CNPJ a ser formatada para exibição.
Retorna:
- str: O CNPJ formatado com sÃmbolos visuais se for válido, None se não for válido.
Exemplo:
```python
>>> from brutils import format_cnpj
>>> format_cnpj("03560714000142")
'03.560.714/0001-42'
>>> format_cnpj("98765432100100")
None
```### remove_symbols_cnpj
Remove sÃmbolos especÃficos de uma string de CNPJ (Cadastro Nacional da Pessoa
JurÃdica).
Esta função recebe uma string de CNPJ como entrada e remove todas as
ocorrências dos caracteres '.', '/' e '-' dela.Argumentos:
- cnpj (str): A string de CNPJ que contém os sÃmbolos a serem removidos.
Retorna:
- str: Uma nova string com os sÃmbolos especificados removidos.
Exemplo:
```python
>>> from brutils import remove_symbols_cnpj
>>> remove_symbols_cnpj('00.111.222/0001-00')
'00111222000100'
```### generate_cnpj
Gera uma string de dÃgitos CNPJ válida aleatória. Um número de filial
opcional pode ser fornecido; o padrão é 1.Argumentos:
- branch (int): Um número de filial opcional a ser incluÃdo no CNPJ.
Retorna:
- str: Um CNPJ válido gerado aleatoriamente.
Exemplo:
```python
>>> from brutils import generate_cnpj
>>> generate_cnpj()
'34665388000161'
>>> generate_cnpj(1234)
"01745284123455"
```## CEP
### is_valid_cep
Verifica se um CEP (Código de Endereçamento Postal) brasileiro é válido.
Para que um CEP seja considerado válido, a entrada deve ser uma string contendo
exatamente 8 dÃgitos. Esta função não verifica se o CEP é um CEP real, pois
valida apenas o formato da string.Argumentos:
- cep (str): A string contendo o CEP a ser verificado.
Retorno:
- bool: True se o CEP for válido (8 dÃgitos), False caso contrário.
Exemplo:
```python
>>> from brutils import is_valid_cep
>>> is_valid_cep('01310200')
True
>>> is_valid_cep("12345")
False
>>> is_valid_cep("abcdefgh")
False
```### format_cep
Formata um CEP (Código de Endereçamento Postal) brasileiro em um formato padrão.
Esta função recebe um CEP como entrada e, se for um CEP válido com 8 dÃgitos,
o formata no padrão "12345-678".Argumentos:
- cep (str): O CEP (Código de Endereçamento Postal) de entrada a ser
formatado.Retorna:
- str: O CEP formatado no formato "12345-678" se for válido, None se não for
válido.Example:
```python
>>> from brutils import format_cep
>>> format_cep('01310200')
'01310-200'
>>> format_cep("12345678")
"12345-678"
>>> format_cep("12345")
None
```### remove_symbols_cep
Remove sÃmbolos especÃficos de um CEP (Código de Endereçamento Postal)
fornecido. Esta função recebe um CEP como entrada e remove todas as ocorrências
dos caracteres '.' e '-' dele.Argumentos:
- cep (str): O CEP (Código de Endereçamento Postal) de entrada que contém os
sÃmbolos a serem removidos.Retorna:
- str: Uma nova string com os sÃmbolos especificados removidos.
Exemplo:
```python
>>> from brutils import remove_symbols_cep
>>> remove_symbols_cep('01310-200')
'01310200'
>>> remove_symbols_cep("123-45.678.9")
"123456789"
>>> remove_symbols_cep("abc.xyz")
"abcxyz"
```### generate_cep
Gera um número de CEP (Código de Endereçamento Postal) aleatório de 8 dÃgitos
como uma string.Retorna:
- str: Um número de 8 dÃgitos gerado aleatoriamente.
Exemplo:
```python
>>> from brutils import generate_cep
>>> generate_cep()
'77520503'
>>> generate_cep()
'29641407'
```### get_address_from_cep
Busca as informações de endereço a partir de um CEP (Código de Endereçamento Postal) utilizando a API da ViaCEP.
Argumentos:
- cep (str): O CEP a ser utilizado na busca.
- raise_exceptions (bool, opcional): Se deve gerar exceções quando o CEP for inválido ou não for encontrado. O padrão é False.Retorna:
- Address | None: Um objeto Address (TypedDict) contendo as informações de endereço se o CEP for encontrado, caso contrário, None.
Exemplo:
```python
>>> from brutils import get_address_from_cep
>>> get_address_from_cep("12345678")
{
"cep": "12345-678",
"logradouro": "Rua Example",
"complemento": "",
"bairro": "Example",
"localidade": "Example",
"uf": "EX",
"ibge": "1234567",
"gia": "1234",
"ddd": "12",
"siafi": "1234"
}
```### get_cep_information_from_address
Busca o CEP e outras informações a partir de um endereço utilizando a API da ViaCEP.
Argumentos:
- federal_unit (str): Abreviação de duas letras do estado brasileiro.
- city (str): Nome da cidade.
- street (str): Nome (ou substring) da rua.
- raise_exceptions (bool, opcional): Se deve gerar exceções quando o endereço é inválido ou não foi encontrado. O padrão é False.Retorna:
- list[Address] | None: Uma lista de objetos Address (TypedDict) contendo as informações de endereço se o endereço for encontrado, None caso contrário.
Exemplo:
```python
>>> from brutils import get_cep_information_from_address
>>> get_cep_information_from_address("EX", "Example", "Rua Example")
[
{
"cep": "12345-678",
"logradouro": "Rua Example",
"complemento": "",
"bairro": "Example",
"localidade": "Example",
"uf": "EX",
"ibge": "1234567",
"gia": "1234",
"ddd": "12",
"siafi": "1234"
}
]
```## Telefone
### is_valid_phone
Retorna se um número de telefone brasileiro é válido conforme o formato da string.
Não verifica se o número realmente existe.
```is_valid_phone(phone_number, type)
```
Argumentos:
- phone_number (str):
- o número de telefone a ser validado
- apenas dÃgitos, sem sÃmbolos
- sem o código do paÃs
- deve incluir o número de DDD com dois dÃgitos
- exemplo: '+55 48 9999 9999' deve ser utilizado como '4899999999'
- obrigatório- type (str):
- 'mobile' para validar apenas números de celular
- 'landline' para validar apenas números de telefone fixo
- caso não especificado, valida para um para o outro.
- opcionalRetorna:
- bool: True se o número é válido, False caso contrário.
Exemplo:
```python
>>> from brutils import is_valid_phone
>>> is_valid_phone('11994029275')
True
>>> is_valid_phone('11994029275', 'mobile')
True
>>> is_valid_phone('1938814933', 'landline')
True
```### format_phone
Formata um número de telefone para exibição visual. Esta função recebe uma string representando um número de telefone contendo apenas números como entrada e adiciona sÃmbolos de formatação padrão para exibição.
Argumentos:
- phone (str): Uma string representando um número de telefone.
Retorna:
- str: O número de telefone formatado para exibição ou None se não for válido.
Exemplo:
```python
>>> from brutils import format_phone
>>> format_phone("11994029275")
'(11)99402-9275'
>>> format_phone("1635014415")
'(16)3501-4415'
>>> format_phone("333333")
None
```### remove_symbols_phone
Remove sÃmbolos do número de telefone. Esta função recebe um número de telefone como entrada e remove todos os sÃmbolos, como parênteses '()', traços '-' e espaços ' '.
Argumentos:
- phone (str): O número de telefone de entrada que contém os sÃmbolos a serem removidos.
Retorna:
- str: Uma nova string com os sÃmbolos especificados removidos.
Exemplo:
```python
>>> from brutils import remove_symbols_phone
>>> remove_symbols_phone('(21)2569-6969')
'2125696969'
>>> remove_symbols_phone('11 9999-8888')
'1199998888'
>>> remove_symbols_phone('333333')
'333333'
```### remove_international_dialing_code
Remove o código internacional (+55) de uma string que contém um número de telefone brasileiro, mantendo outros caracteres especiais.
Argumentos:
- phone (str): O número de telefone de entrada que pode conter o código internacional.
Retorna:
- str: Uma nova string sem o código internacional, preservando outros caracteres especiais.
Exemplo:
```python
>>> from brutils import remove_international_dialing_code
>>> remove_international_dialing_code("5521994029275")
"21994029275"
>>> remove_international_dialing_code("+5521994029275")
"+21994029275"
>>> remove_international_dialing_code("5555994029275")
"55994029275"
>>> remove_international_dialing_code("21994029275")
"21994029275"
>>> remove_international_dialing_code("(+55)21994029275")
"(+)21994029275"
```### generate_phone
Gera um número de telefone aleatório válido.
Argumentos:
- type (str): Pode ser "landline" ou "mobile".
Se não for especificado, a função gera um número
aleatório de qualquer tipo.Retorna:
- str: Um número de telefone válido gerado aleatoriamente.
Exemplo:
```python
>>> from brutils import generate_phone
>>> generate_phone()
"5929797740"
>>> generate_phone("mobile")
"1899115895"
>>> generate_phone("landline")
"5535317900"
```### is_valid_email
Verificar se uma string corresponde a um endereço de e-mail válido.
Argumentos:
- email (str): A string de entrada a ser verificada.
Retorna:
- bool: Verdadeiro se o email for um endereço de e-mail válido, Falso
caso contrário.Exemplo:
```python
from brutils import is_valid_email>>> is_valid_email("[email protected]")
True
>>> is_valid_email("[email protected]")
False
>>> is_valid_email("joao.ninguem@gmail.")
False
>>> is_valid_email("joao [email protected]")
False
```## Placa de Carro
### is_valid_license_plate
Verifica se uma placa de carro é válida.
Esta função não verifica se a placa de carro é uma placa de carro real,
apenas valida o formato da string.Argumentos:
- license_plate (str): Uma string representando uma placa de carro.
- type (str): "old_format" ou "mercosul".
Se não especificado, verifica um ou outro.Retorna:
- bool: True se a placa de carro for válida, False caso contrário.
Exemplo:
```python
>>> from brutils import is_valid_license_plate
>>> is_valid_license_plate('ABC1234')
True
>>> is_valid_license_plate('def5678', type="old_format")
True
>>> is_valid_license_plate('ABC4E67')
True
>>> is_valid_license_plate('ABC4E67', type="mercosul")
True
>>> is_valid_license_plate('GHI-4567')
False
```### format_license_plate
Formata uma placa de carro no padrão correto.
Esta função recebe uma placa de carro em qualquer formato (LLLNNNN ou LLLNLNN) e retorna uma versão formatada.Argumentos:
- license_plate (str): Uma string representando uma placa de carro.
Retorna:
- str: A string da placa de carro formatada ou
'None' se a entrada for inválida.Exemplo:
```python
>>> from brutils import format_license_plate
>>> format_license_plate("ABC1234")
"ABC-1234"
# formato antigo (contém traço)
>>> format_license_plate("abc1234")
"ABC-1234"
# formato antigo (contém traço)
>>> format_license_plate("ABC1D23")
"ABC1D23"
# formato mercosul
>>> format_license_plate("abc1d23")
"ABC1D23"
# formato mercosul
>>> format_license_plate("ABCD123")
None
```### remove_symbols_license_plate
Remove o sÃmbolo de hÃfen (-) de uma string de placa de carro.
Argumentos:
- license_plate_number (str): Uma string de placa de carro contendo sÃmbolos a serem removidos.
Retorna:
- str: A string da placa de carro com os sÃmbolos especificados removidos.
Exemplo:
```python
from brutils import remove_symbols_license_plate
>>> remove_symbols_license_plate("ABC-123")
"ABC123"
>>> remove_symbols_license_plate("abc123")
"abc123"
>>> remove_symbols_license_plate("ABCD123")
"ABCD123"
>>> remove_symbols_license_plate("@abc#-#123@")
"@abc##123@"
```### generate_license_plate
Gera uma placa de carro válida no formato especificado. Caso nenhum formato seja fornecido, ele retornará uma placa de carro no formato Mercosul.
Argumentos:
- format (str): O formato desejado para a placa de carro. 'LLLNNNN' para o formato antigo ou 'LLLNLNN' para o formato Mercosul. O padrão é 'LLLNLNN'.
Retorna:
- str: Um número de placa de carro gerado aleatoriamente ou
None se o formato for inválido.Exemplo:
```python
from brutils import generate_license_plate
>>> generate_license_plate()
"ABC1D23"
>>> generate_license_plate(format="LLLNLNN")
"ABC4D56"
>>> generate_license_plate(format="LLLNNNN")
"ABC123"
>>> generate_license_plate(format="invalid")
None
```### convert_license_plate_to_mercosul
Converte uma placa de carro no formato antigo (LLLNNNN) para o formato Mercosul (LLLNLNN).
Argumentos:
- license_plate(str): Uma string com o tamanho adequado que representa a placa no formato antigo.
Retorna:
- str: A placa Mercosul convertida (LLLNLNN) ou None se a entrada for inválida.
Exemplo:
```python
>>> from brutils import convert_license_plate_to_mercosul
>>> convert_license_plate_to_mercosul("ABC123")
"ABC1C34"
>>> convert_license_plate_to_mercosul("abc123")
"ABC1C34"
>>> convert_license_plate_to_mercosul("ABC1D23")
None
```### get_format_license_plate
Retorna o formato de uma placa de carro. 'LLLNNNN' para o formato antigo e
'LLLNLNN' para o formato Mercosul.Argumentos:
- license_plate (str): Uma string de placa de carro sem sÃmbolos.
Retorna:
- str: O formato da placa de carro (LLLNNNN, LLLNLNN) ou
'None' se o formato for inválido.Exemplo:
```python
from brutils import get_format_license_plate
>>> get_format_license_plate("ABC123")
"LLLNNNN"
>>> get_format_license_plate("abc123")
"LLLNNNN"
>>> get_format_license_plate("ABC1D23")
"LLLNLNN"
>>> get_format_license_plate("abc1d23")
"LLLNLNN"
>>> get_format_license_plate("ABCD123")
None
```## PIS
### is_valid_pis
Verifica se o número PIS/PASEP é valido. Apenas números, formatados como string. Não verifica se o PIS/PASEP realmente existe.
Referências:
- .
Argumentos:
- pis (str): Número PIS como uma string com o comprimento apropriado.
Retorna:
- bool: True se o PIS for válido, False caso contrário.
Exemplo:
```python
from brutils import is_valid_pis
>>> is_valid_pis("82178537464")
False
>>> is_valid_pis("12082043519")
True
```### format_pis
Formata uma string de PIS (Programa de Integração Social) válida com sÃmbolos e adiciona sÃmbolos de formatação padrão para exibição.
Argumentos:
- pis (str): Uma string válida de PIS contendo apenas números.
Retorna:
- str: Uma string de PIS formatada com sÃmbolos visuais padrão ou None se a entrada for inválida.
Exemplo:
```python
from brutils import format_pis
>>> format_pis("17033259504")
'170.33259.50-4'
>>> format_pis("12013128292")
'120.13128.29-2'
```### remove_symbols_pis
Esta função recebe uma string de PIS (Programa de Integração Social) com sÃmbolos de formatação e retorna uma versão limpa sem sÃmbolos. Remove apenas os sÃmbolos "-" e "." , propositalmente não remove outros sÃmbolos.
Argumentos:
- pis (str): Uma string de PIS que pode conter sÃmbolos de formatação.
Retorna:
- str: Uma string de PIS limpa, sem sÃmbolos de formatação.
Exemplo:
```python
from brutils import remove_symbols_pis>>> remove_symbols_pis('170.33259.50-4')
'17033259504'
>>> remove_symbols_pis("123.456.789-09")
'12345678909'
>>> remove_symbols_pis('/._')
'/_'
```### generate_pis
Gera uma string de dÃgitos contendo um número de um PIS brasileiro válido aleatório.
Retorna:
- str: Um número PIS válido gerado aleatoriamente como string.
Exemplo:
```python
from brutils import generate_pis
>>> generate_pis()
'61352489741'
>>> generate_pis()
'73453349671'
```## Processo JurÃdico
## is_valid_legal_process
Verifica se um ID de processo jurÃdico é válido, não verifica se o ID de processo jurÃdico é um ID de processo
jurÃdico real; ela apenas valida o formato da string.Argumentos:
- legal_process_id (str): Uma string contendo apenas dÃgitos que representa
o ID do processo jurÃdico.Retorna:
- bool: True se o ID do processo jurÃdico for válido, False caso
contrário.Examplo:
```python
>>> from brutils import is_valid_legal_process
>>> is_valid_legal_process('10188748220234018200')
True
>>> is_valid_legal_process('45532346920234025107')
True
>>> is_valid_legal_process('00000000000000000000')
False
>>> is_valid_legal_process('455323423QQWEQWSsasd&*(()')
False
>>>
```### format_legal_process
Formata um ID de processo jurÃdico em um formato padrão.
Argumentos:
- legal_process_id (str): Uma string de 20 dÃgitos que representa o ID do
processo jurÃdico.Retorna:
- str: O ID do processo jurÃdico formatado ou None se a entrada for inválida.
Exemplo:
```python
>>> from brutils import format_legal_process
>>> format_legal_process('23141945820055070079')
'2314194-58.2005.5.07.0079'
>>> format_legal_process('00000000000000000000')
'0000000-00.0000.0.00.0000'
>>>
```### remove_symbols_legal_process
Remove sÃmbolos especÃficos de um processo jurÃdico fornecido.
Esta função recebe um processo jurÃdico como entrada e remove todas as
ocorrências dos caracteres '.' e '-' dele.Argumentos:
- legal_process (str): Um processo jurÃdico contendo sÃmbolos a serem
removidos.Retorna:
- str: A string do processo jurÃdico com os sÃmbolos especificados removidos.
Exemplo:
```python
from brutils import remove_symbols_legal_process
>>> remove_symbols_legal_process("6439067-89.2023.4.04.5902")
"64390678920234045902"
>>> remove_symbols_legal_process("4976023-82.2012.7.00.2263")
"49760238220127002263"
>>> remove_symbols_legal_process("4976023-82.2012.7.00.2263*!*")
"49760238220127002263*!*"
```### generate_legal_process
Gera um número válido aleatório de ID de processo jurÃdico.
Argumentos:
- year (int): O ano para o ID do processo jurÃdico (o padrão é o ano atual).
Não pode ser um ano do passado.
- orgao (int): O órgão (1-9) para o ID do processo jurÃdico
(o padrão é aleatório).Retorna:
- str: Um ID de processo jurÃdico gerado aleatoriamente.
None caso algum dos argumento seja inválido.Exemplo:
```python
>>> from brutils import generate_legal_process
>>> generate_legal_process()
"45676401020238170592"
>>> generate_legal_process(ano=2025)
"32110268020258121130"
>>> generate_legal_process(orgao=5)
"37573041520235090313"
>>> generate_legal_process(ano=2024, orgao=4)
"33158248820244017105"
```## Titulo Eleitoral
### is_valid_voter_id
Verifica se um número de TÃtulo de Eleitor brasileiro é válido. Não verifica se realmente existe.
Referências:
-
-Argumentos:
- voter_id (str): string representando o número do tÃtulo de eleitor a ser verificado.
Retorna:
- bool: True se o número do tÃtulo de eleitor for válido. False, caso contrário.
Exemplo:
```python
>>> from brutils import is_valid_voter_id
>>> is_valid_voter_id('123456789011')
False
>>> is_valid_voter_id('427503840213')
True
```### format_voter_id
Formata um número de TÃtulo de Eleitor para exibição visual.
Esta função recebe uma string de TÃtulo de Eleitor contendo
apenas números como entrada e adiciona os espaços de formatação
padrão para exibição.Argumentos:
* voter_id (str): Uma string de TÃtulo de Eleitor contendo apenas números.Retorna:
* str: O TÃtulo de Eleitor formatado com os espaços, se for válido.
Retorna None se não for válido.Exemplo:
```python
>>> from brutils import format_voter_id
>>> format_voter_id("246593980493")
'2465 9398 04 93'
>>> format_voter_id("202715292895")
'2027 1529 28 95'
>>> format_voter_id("739035552205")
>>>
```### generate_voter_id
Gera uma string de dÃgitos de TÃtulo de Eleitor válida aleatória a partir de um estado brasileiro informado.
Args:
* federative_union (str): Unidade Federativa para o tÃtulo de eleitor que será gerado. O valor padrão "ZZ" é usado para TÃtulos de Eleitor emitidos para estrangeiros.Retorna:
* str: Um TÃtulo de Eleitor válido gerado aleatoriamente.Exemplo:
```python
>>> from brutils import generate_voter_id
>>> generate_voter_id()
'183475722801'
>>> generate_voter_id(federative_union ="MG")
'950125640248'
```## IBGE
### convert_code_to_uf
Converte um determinado código do IBGE (string de 2 dÃgitos) para sua UF (abreviatura estadual) correspondente.Args:
* code (str): O código IBGE de 2 dÃgitos a ser convertido.Retorna:
* str or None: O código UF correspondente ao código IBGE, ou None se o
código IBGE for inválido.Exemplo:
```python
>>> from brutils.ibge.uf import convert_code_to_uf
>>> convert_code_to_uf("12")
'AC'
>>> convert_code_to_uf("33")
'RJ'
>>> convert_code_to_uf("99")
>>>
```# Novos Utilitários e Reportar Bugs
Caso queira sugerir novas funcionalidades ou reportar bugs, basta criar
uma nova [issue][github-issues] e iremos lhe responder por lá!(Para saber mais sobre github issues, confira a [documentação oficial do GitHub][github-issues-doc]).
# Dúvidas? Ideias?
Dúvidas de como utilizar a biblioteca? Novas ideias para o projeto?
Quer compartilhar algo com a gente? Fique à vontade para criar um tópico no nosso
[Discussions][github-discussions] que iremos interagir por lá!(Para saber mais sobre github discussions, confira a
[documentação oficial do GitHub][github-discussions-doc]).# Contribuindo com o Código do Projeto
Sua colaboração é sempre muito bem-vinda! Preparamos o arquivo [CONTRIBUTING.md][contributing] para
te ajudar nos primeiros passos. Lá você encontrará toda a informação necessária para contribuir com
o projeto. Não hesite em nos perguntar utilizando o [GitHub Discussions][github-discussions] caso
haja qualquer dificuldade ou dúvida. Toda ajuda conta!Vamos construir juntos! 🚀🚀
[contributing]: CONTRIBUTING.md
[github-discussions-doc]: https://docs.github.com/pt/discussions
[github-discussions]: https://github.com/brazilian-utils/brutils-python/discussions
[github-issues-doc]: https://docs.github.com/pt/issues/tracking-your-work-with-issues/creating-an-issue
[github-issues]: https://github.com/brazilian-utils/brutils-python/issues