Skip to content

Commit

Permalink
Merge branch 'main' into 414
Browse files Browse the repository at this point in the history
  • Loading branch information
vianaz authored Dec 19, 2024
2 parents d57c13d + 3e1d2cc commit 93598bf
Show file tree
Hide file tree
Showing 16 changed files with 6,166 additions and 8 deletions.
2 changes: 1 addition & 1 deletion .github/workflows/run-tests.yml
Original file line number Diff line number Diff line change
Expand Up @@ -18,7 +18,7 @@ jobs:
python-version: ${{ matrix.python-version }}
- name: Generate Report
run: |
pip install coverage
pip install coverage num2words
coverage run -m unittest discover tests/
- name: Upload Coverage to Codecov
uses: codecov/codecov-action@v4
Expand Down
3 changes: 3 additions & 0 deletions CHANGELOG.md
Original file line number Diff line number Diff line change
Expand Up @@ -9,8 +9,11 @@ and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0
### Added

- Utilitário `convert_code_to_uf` [#397](https://github.com/brazilian-utils/brutils-python/pull/410)
- Utilitário `convert_date_to_text`[#394](https://github.com/brazilian-utils/brutils-python/pull/415)
- Utilitário `get_municipality_by_code` [412](https://github.com/brazilian-utils/brutils-python/pull/412)

- Utilitário `get_code_by_municipality_name` [#399](https://github.com/brazilian-utils/brutils-python/issues/399)

## [2.2.0] - 2024-09-12

### Added
Expand Down
26 changes: 24 additions & 2 deletions CONTRIBUTING.md
Original file line number Diff line number Diff line change
Expand Up @@ -80,7 +80,7 @@ Switched to a new branch '386'

### 7. Execute o brutils Localmente

#### Instalação
#### Instalação com poetry

##### Requisitos

Expand All @@ -98,7 +98,7 @@ emulate bash -c '. .../bin/activate'
Para testar se o ambiente virtual está ativo corretamente, execute o comando e verifique se a resposta é algo parecido com a seguinte:

```sh
$ poetry env inf
$ poetry env info
Virtualenv
Python: 3.x.y
Implementation: CPython
Expand All @@ -117,6 +117,28 @@ Installing dependencies from lock file
...
```

#### Instalação com pip

Se preferir usar pip, você pode instalar o projeto em modo de desenvolvimento da seguinte forma:

##### Requisitos

- [Python 3.8+][python]
- [pip][pip]

Crie um [virtualenv][virtualenv] para o brutils e o ative através do comando:

```sh
python -m venv venv
source venv/bin/activate # No Windows use: venv\Scripts\activate
```

Utilize o comando pip para instalar as dependencias de dev e testes através do arquivo requirements-dev.txt

```sh
pip install -r requirements-dev.txt
```

#### Utilizando Localmente

Agora você pode usá-lo [da mesma forma descrita no arquivo README.md](/README.md#utilização).
Expand Down
24 changes: 23 additions & 1 deletion CONTRIBUTING_EN.md
Original file line number Diff line number Diff line change
Expand Up @@ -75,7 +75,7 @@ Switched to a new branch '386'

### 7. Run brutils locally

## Installation
## Installation with poetry

### Requirements

Expand Down Expand Up @@ -112,6 +112,28 @@ Installing dependencies from lock file
...
```

## Installation with pip

If you prefer to use pip, you can install the project in development mode as follows:

### Requirements

- [Python 3.8+][python]
- [pip][pip]

Create a [virtualenv][virtualenv] for brutils and activate it using the following command:

```sh
python -m venv venv
source venv/bin/activate # On Windows use: venv\Scripts\activate
```

Use the pip command to install the dev and test dependencies through the requirements-dev.txt file:

```sh
pip install -r requirements-dev.txt
```

## Using locally

Now, you can use it [in the same way described in the README.md file](/README_EN.md#usage).
Expand Down
60 changes: 60 additions & 0 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -66,6 +66,8 @@ False
- [generate\_phone](#generate_phone)
- [Email](#email)
- [is\_valid\_email](#is_valid_email)
- [Data](#date)
- [convert\_date\_to_text](#convert_date_to_text)
- [Placa de Carro](#placa-de-carro)
- [is\_valid\_license\_plate](#is_valid_license_plate)
- [format\_license\_plate](#format_license_plate)
Expand All @@ -88,6 +90,7 @@ False
- [format_voter_id](#format_voter_id)
- [generate_voter_id](#generate_voter_id)
- [IBGE](#ibge)
- [get_code_by_municipality_name](#get_code_by_municipality_name)
- [convert_code_to_uf](#convert_code_to_uf)
- [get\_municipality\_by\_code](#get_municipality_by_code)

Expand Down Expand Up @@ -629,6 +632,33 @@ False
False
```

## Data

## convert_date_to_text

Converte uma data em sua representação textual.

Argumentos:
- date (str): Uma string no formato dd/mm/aaaa

Retorna:
- A represetação textual da data ou None caso a data esteja mal formatada ou a data seja inválida.

Exemplo:

````python
>>> from brutils import convert_date_to_text
>>> convert_date_to_text("25/12/2000")
"Vinte e cinco de dezembro de dois mil"
>>> convert_date_to_text("31/02/2000")
None
>>> convert_date_to_text("29/02/2024")
"Vinte e nove de fevereiro de dois mil e vinte e quatro"
>>> convert_date_to_text("1/08/2024")
"Primeiro de agosto de dois mil e vinte e quatro"
````


## Placa de Carro

### is_valid_license_plate
Expand Down Expand Up @@ -1130,6 +1160,36 @@ Example:
("São Paulo", "SP")
```

### get_code_by_municipality_name

Retorna o código IBGE para um dado nome de município e código de UF.

Essa função recebe uma string representando o nome de um município e o código da UF, e retorna o código IBGE correspondente (string). A função lida com os nomes ignorando diferenças de maiúsculas, acentos, tratando o caractere "ç" como "c", e ignorando diferenças de maiúsculas para o código da UF.

Argumentos:
* municipality_name (str): O nome do município.
* uf (str): O código UF do estado.

Retorna:
* str: O código IBGE do município. Retorna None se o nome não for válido ou não existir.

Exemplo:

```python
>>> from brutils import get_code_by_municipality_name
>>> get_code_by_municipality_name("São Paulo", "SP")
"3550308"
>>> get_code_by_municipality_name("goiania", "go")
"5208707"
>>> get_code_by_municipality_name("Conceição do Coité", "BA")
"2908408"
>>> get_code_by_municipality_name("conceicao do Coite", "Ba")
"2908408"
>>> get_code_by_municipality_name("Municipio Inexistente", "")
None
>>> get_code_by_municipality_name("Municipio Inexistente", "RS")
None
```
# Novos Utilitários e Reportar Bugs

Caso queira sugerir novas funcionalidades ou reportar bugs, basta criar
Expand Down
63 changes: 63 additions & 0 deletions README_EN.md
Original file line number Diff line number Diff line change
Expand Up @@ -58,6 +58,8 @@ False
- [generate\_cep](#generate_cep)
- [get\_address\_from\_cep](#get_address_from_cep)
- [get\_cep\_information\_from\_address](#get_cep_information_from_address)
- [Date](#date)
- [convert\_date\_to_text](#convert_date_to_text)
- [Phone](#phone)
- [is\_valid\_phone](#is_valid_phone)
- [format\_phone](#format_phone)
Expand Down Expand Up @@ -90,6 +92,7 @@ False
- [IBGE](#ibge)
- [convert_code_to_uf](#convert_code_to_uf)
- [get\_municipality\_by\_code](#get_municipality_by_code)
- [get_code_by_municipality_name](#get_code_by_municipality_name)

## CPF

Expand Down Expand Up @@ -449,6 +452,32 @@ Example:
]
```

## Date

### convert_date_to_text
Convert a brazilian date (dd/mm/yyyy) format in their portuguese textual representation.

Args:
- date (str): A date in a string format dd/mm/yyyy.

Return:
- (str) | None: A portuguese textual representation of the date or None case a date is invalid.


Example:

````python
>>> from brutils import convert_date_to_text
>>> convert_date_to_text("25/12/2000")
"Vinte e cinco de dezembro de dois mil"
>>> convert_date_to_text("31/02/2000")
None
>>> convert_date_to_text("29/02/2024")
"Vinte e nove de fevereiro de dois mil e vinte e quatro"
>>> convert_date_to_text("1/08/2024")
"Primeiro de agosto de dois mil e vinte e quatro"
````

## Phone

### is_valid_phone
Expand Down Expand Up @@ -1132,6 +1161,40 @@ Example:
("São Paulo", "SP")
```

### get_code_by_municipality_name

Returns the IBGE code for a given municipality name and uf code.

This function takes a string representing a municipality's name
and uf's code and returns the corresponding IBGE code (string). The function
will handle names by ignoring differences in case, accents, and
treating the character ç as c and ignoring case differences for the uf code.

Args:
* municipality_name (str): The name of the municipality.
* uf (str): The uf code of the state.

Returns:
* str: The IBGE code of the municipality. Returns None if the name is not valid or does not exist.

Example:

```python
>>> from brutils import get_code_by_municipality_name
>>> get_code_by_municipality_name("São Paulo", "SP")
"3550308"
>>> get_code_by_municipality_name("goiania", "go")
"5208707"
>>> get_code_by_municipality_name("Conceição do Coité", "BA")
"2908408"
>>> get_code_by_municipality_name("conceicao do Coite", "Ba")
"2908408"
>>> get_code_by_municipality_name("Municipio Inexistente", "")
None
>>> get_code_by_municipality_name("Municipio Inexistente", "RS")
None
```

# Feature Request and Bug Report

If you want to suggest new features or report bugs, simply create
Expand Down
11 changes: 9 additions & 2 deletions brutils/__init__.py
Original file line number Diff line number Diff line change
Expand Up @@ -42,13 +42,17 @@
remove_symbols as remove_symbols_cpf,
)

# Date imports
from brutils.date import convert_date_to_text

# Email Import
from brutils.email import is_valid as is_valid_email

# IBGE Imports
from brutils.ibge.municipality import (
get_code_by_municipality_name,
get_municipality_by_code,
)

# IBGE Imports
from brutils.ibge.uf import (
convert_code_to_uf,
)
Expand Down Expand Up @@ -144,6 +148,8 @@
"generate_cpf",
"is_valid_cpf",
"remove_symbols_cpf",
# Date
"convert_date_to_text",
# Email
"is_valid_email",
# Legal Process
Expand Down Expand Up @@ -176,4 +182,5 @@
# IBGE
"convert_code_to_uf",
"get_municipality_by_code",
"get_code_by_municipality_name",
]
Loading

0 comments on commit 93598bf

Please sign in to comment.