Skip to main content

No project description provided

Project description

etl-ativa-investimentos

Biblioteca Python para leitura dos arquivos Excel exportados pela corretora Ativa Investimentos, convertendo-os em pandas.DataFrame prontos para análise, pipelines de dados e integrações ETL.


Instalação

pip install etl-ativa-investimentos

Requisitos: Python >= 3.11


Motivação

A Ativa Investimentos exporta relatórios em Excel com múltiplas abas e nomes de colunas em português. Esta biblioteca abstrai a leitura desses arquivos, entregando DataFrames limpos e prontos para uso — sem precisar se preocupar com nomes de abas, encoding ou engine de leitura.


Módulos

A lib é organizada por tipo de relatório. Cada módulo expõe:

  • Funções individuais por aba: read_<nome_da_aba>(path)
  • Uma função read_all(path) que retorna todas as abas como dict[str, DataFrame]

posicao_consolidada

Lê o relatório de Posição Consolidada (.xls), disponível no portal da corretora.

from etl_ativa_investimentos import posicao_consolidada

path = "posicao_consolidada/2025_12_30.xls"

# Aba individual
df_acoes = posicao_consolidada.read_acoes(path)
df_rf    = posicao_consolidada.read_renda_fixa_privada(path)

# Todas as abas de uma vez
data = posicao_consolidada.read_all(path)
Função Aba do Excel Colunas principais
read_acoes(path) Ações Código, Nome, Carteira, Quantidade, Preço, Total
read_clubes_e_fundos(path) Clubes e Fundos Nome do fundo, Data, Valor Aplicação, Cota, Valor
read_financeiro(path) Financeiro Conta, Tipo, Disponível, Projeção, Total
read_renda_fixa_privada(path) Renda Fixa Privada Ticker, Emissor, Remuneração, PU Atual, Quantidade, Total
read_renda_fixa_publica(path) Renda Fixa Pública Título, Emissor, Indexador, Data Vencimento, PU Atual, Total
read_all(path) Todas Retorna dict[str, DataFrame]

Chaves retornadas por read_all:

{
    "acoes": ...,
    "clubes_e_fundos": ...,
    "financeiro": ...,
    "renda_fixa_privada": ...,
    "renda_fixa_publica": ...,
}

carteira_cotizada

Lê o relatório de Carteira Cotizada / Painel (.xlsx), exportado pelo sistema SIM da corretora.

from etl_ativa_investimentos import carteira_cotizada

path = "SIM.PAINEL.2026.01.30.10.01.36.xlsx"

# Aba individual
df = carteira_cotizada.read_carteira_analitica(path)

# Todas as abas de uma vez
data = carteira_cotizada.read_all(path)
Função Conteúdo
read_variacao_patrimonial(path) Patrimônio bruto, líquido e variação percentual
read_composicao_patrimonio(path) Composição por classe de ativo com provisões de IR e IOF
read_carteira_analitica(path) Posição consolidada com preços, financeiros e L/P
read_rentabilidade_carteira(path) Performance: dia, mês, 30 dias, ano, 12 meses, início
read_rentabilidade_no_ano(path) Rentabilidade mensal no ano corrente por ativo
read_rentabilidade_ultimos_meses(path) Histórico mensal comparado ao CDI e IBOVESPA
read_rentabilidade_ativos(path) Performance individual por ativo em múltiplos períodos
read_provisoes(path) Provisões de IR e IOF com datas e valores
read_renda_fixa_detalhada(path) CDBs e títulos com PU de aquisição, atual, IR e IOF
read_clubes_e_fundos_detalhados(path) Fundos com cotas, L/P, IR, IOF e valor líquido
read_all(path) Todas as abas — retorna dict[str, DataFrame]

Chaves retornadas por read_all:

{
    "variacao_patrimonial": ...,
    "composicao_patrimonio": ...,
    "carteira_analitica": ...,
    "rentabilidade_carteira": ...,
    "rentabilidade_no_ano": ...,
    "rentabilidade_ultimos_meses": ...,
    "rentabilidade_ativos": ...,
    "provisoes": ...,
    "renda_fixa_detalhada": ...,
    "clubes_e_fundos_detalhados": ...,
}

movimentacao_b3

Lê o relatório de Movimentação B3 (.xlsx), exportado diretamente pelo portal da B3 ou pela corretora.

from etl_ativa_investimentos import movimentacao_b3

path = "movimentacao-2023-01-01-ate-31-12-2023.xlsx"

# Aba individual
df = movimentacao_b3.read_movimentacao(path)

# Todas as abas de uma vez
data = movimentacao_b3.read_all(path)
Função Aba do Excel Colunas principais
read_movimentacao(path) Movimentação Entrada/Saída, Data, Movimentação, Produto, Instituição, Quantidade, Preço unitário, Valor da Operação
read_all(path) Todas Retorna dict[str, DataFrame]

Chaves retornadas por read_all:

{
    "movimentacao": ...,
}

Interface orientada a objetos (readers)

Além das funções funcionais, a lib oferece classes que encapsulam leitura, cache e validação:

from etl_ativa_investimentos.readers.carteira_cotizada import CarteiraCotzada
from etl_ativa_investimentos.readers.posicao_consolidada import PosicaoConsolidada
from etl_ativa_investimentos.readers.movimentacao_b3 import MovimentacaoB3

Cada classe segue o mesmo contrato:

Método Descrição
.<aba>() Retorna o DataFrame da aba (lazy load + cache)
.load() Carrega todas as abas em memória de uma vez
.validate_all() Valida todas as abas; retorna ValidationResult
.load_and_print_errors() Carrega, valida e exibe erros formatados

Exemplo

from etl_ativa_investimentos.readers.carteira_cotizada import CarteiraCotzada

carteira = CarteiraCotzada("SIM.PAINEL.2026.01.30.10.01.36.xlsx")

# Lazy load — lê só quando chamado, resultado fica em cache
df = carteira.carteira_analitica()

# Validação estruturada
result = carteira.validate_all()
if not result.ok:
    print(result.errors)  # {"nome_aba": ["mensagem de erro", ...]}

# Ou de forma conveniente
carteira.load_and_print_errors()

Exemplo completo (API funcional)

from etl_ativa_investimentos import (
    posicao_consolidada,
    carteira_cotizada,
    movimentacao_b3,
)

# Posição consolidada
posicao = posicao_consolidada.read_all("posicao_consolidada/2025_12_30.xls")
print(posicao["acoes"])

# Carteira cotizada
painel = carteira_cotizada.read_all("SIM.PAINEL.2026.01.30.10.01.36.xlsx")
print(painel["carteira_analitica"])

# Movimentação B3
mov = movimentacao_b3.read_all("movimentacao-2023-01-01-ate-31-12-2023.xlsx")
print(mov["movimentacao"])

Detalhes técnicos

  • Todos os arquivos são lidos com pandas.read_excel usando o engine calamine — uma implementação em Rust, mais rápida e sem dependência do Java (ao contrário do xlrd/openpyxl para .xls antigos).
  • Suporta tanto .xls (formato legado) quanto .xlsx.
  • Cada função retorna um pandas.DataFrame sem transformações — os dados são entregues exatamente como estão no Excel, para que você decida como processar.

Desenvolvimento

# Clonar e instalar dependências
git clone https://github.com/seu-usuario/etl-ativa-investimentos.git
cd etl-ativa-investimentos
poetry install

# Rodar testes
poetry run pytest -v

Licença

MIT

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

etl_ativa_investimentos-0.1.1.tar.gz (8.4 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

etl_ativa_investimentos-0.1.1-py3-none-any.whl (11.0 kB view details)

Uploaded Python 3

File details

Details for the file etl_ativa_investimentos-0.1.1.tar.gz.

File metadata

  • Download URL: etl_ativa_investimentos-0.1.1.tar.gz
  • Upload date:
  • Size: 8.4 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/2.2.1 CPython/3.10.12 Linux/6.6.87.2-microsoft-standard-WSL2

File hashes

Hashes for etl_ativa_investimentos-0.1.1.tar.gz
Algorithm Hash digest
SHA256 f5ad52b4741efd2acaa1da85b544fce0ab310b885aa19f11a834885593f981ed
MD5 be387853b5254868484b7e8f581a7147
BLAKE2b-256 3b731d52196bb17f6ac0d379933dcd7fb2a5027fa0ba1a7df3360b558d407f36

See more details on using hashes here.

File details

Details for the file etl_ativa_investimentos-0.1.1-py3-none-any.whl.

File metadata

  • Download URL: etl_ativa_investimentos-0.1.1-py3-none-any.whl
  • Upload date:
  • Size: 11.0 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/2.2.1 CPython/3.10.12 Linux/6.6.87.2-microsoft-standard-WSL2

File hashes

Hashes for etl_ativa_investimentos-0.1.1-py3-none-any.whl
Algorithm Hash digest
SHA256 02d529f82cb6c0ad86a1f0130bfc9cb76e995b3dec55be91818b4ddc5db1a0d7
MD5 e3d00a3e619b8ee903e8c395d6cbe399
BLAKE2b-256 58655dc985c4f3bac8fa7b848b6f0f06349d00723c0a567da64e6fbb007eed91

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page