Skip to main content

Analise de dados financeiros do Banco Central do Brasil (BCB)

Project description

ifdata-bcb

PyPI version Python License: MIT CI

Coleta e analise de dados contabeis e financeiros de instituicoes financeiras brasileiras. Dados publicos do Banco Central do Brasil.

Fonte Modulo Dados Periodicidade
COSIF bcb.cosif Plano contabil (individual e prudencial) Mensal
IFDATA bcb.ifdata Informacoes financeiras Trimestral
Cadastro bcb.cadastro Metadados de instituicoes (segmento, conglomerado) Trimestral

Instalacao

uv add ifdata-bcb

Requer Python 3.12+.

Uso Rapido

import ifdata_bcb as bcb

# 1. Coletar dados (primeira vez ou atualizar)
bcb.cadastro.collect('2024-01', '2024-12')
bcb.cosif.collect('2024-01', '2024-12')
bcb.ifdata.collect('2024-01', '2024-12')

# 2. Buscar instituicao por nome (fuzzy matching)
bcb.cadastro.search('Itau')
bcb.cadastro.search('Bradesco')
#    CNPJ_8                       INSTITUICAO  SITUACAO       FONTES  SCORE
# 0  60872504  ITAU UNIBANCO HOLDING S.A.           A  cosif,ifdata    100

# 3. Ler dados usando CNPJ de 8 digitos
# start e OBRIGATORIO (posicional); instituicao e keyword-only e opcional
# start sozinho = data unica; start + end = range

# COSIF (escopo=None busca em todos os escopos)
df = bcb.cosif.read(
    '2024-12',
    instituicao='60872504',
    conta='TOTAL GERAL DO ATIVO',
    escopo='prudencial'
)

# IFDATA
df = bcb.ifdata.read(
    '2024-01',
    '2024-12',
    instituicao='60872504',
    conta='Lucro Liquido'
)

# Bulk read: todas as instituicoes (sem instituicao)
df = bcb.cosif.read('2024-12', escopo='prudencial')

# Enriquecer com dados cadastrais inline
df = bcb.ifdata.read(
    '2024-01',
    '2024-12',
    instituicao='60872504',
    escopo='prudencial',
    cadastro=['TCB', 'SEGMENTO']
)

# Cadastro
df = bcb.cadastro.read('2024-12', segmento='Banco Multiplo')

# 4. Listar valores distintos e contas
bcb.ifdata.list(["RELATORIO"])
bcb.cosif.list(["DATA", "ESCOPO"])
bcb.cadastro.list(["SEGMENTO"], uf='SP')
bcb.cosif.list_contas(escopo='prudencial')

# 5. SQL direto com DuckDB (para analises avancadas)
from ifdata_bcb.infra import QueryEngine

qe = QueryEngine()
df = qe.sql("""
    SELECT CNPJ_8, NOME_INSTITUICAO, SALDO
    FROM '{cache}/cosif/prudencial/*.parquet'
    WHERE DATA_BASE = 202412 AND NOME_CONTA = 'TOTAL GERAL DO ATIVO'
    ORDER BY SALDO DESC
    LIMIT 10
""")

Documentacao

Guias de Uso

Fontes de Dados

Uso Avancado

Arquitetura Interna

Estrutura de Dados

{cache}/
  cosif/
    individual/       # cosif_ind_YYYYMM.parquet
    prudencial/       # cosif_prud_YYYYMM.parquet
  ifdata/
    valores/          # ifdata_val_YYYYMM.parquet
    cadastro/         # ifdata_cad_YYYYMM.parquet

O diretorio de cache varia por sistema:

Sistema Caminho
Windows %LOCALAPPDATA%\py-bacen\Cache\
Linux ~/.cache/py-bacen/
macOS ~/Library/Caches/py-bacen/

Customizavel via variavel de ambiente BACEN_DATA_DIR.

API Publica

Modulo Principal

import ifdata_bcb as bcb

# Explorers (lazy loading)
bcb.cosif       # COSIFExplorer
bcb.ifdata      # IFDATAExplorer
bcb.cadastro    # CadastroExplorer

# Exceptions
bcb.BacenAnalysisError       # Classe base para todos os erros
bcb.DataUnavailableError     # Dados nao disponiveis

Metodos dos Explorers

Todos os explorers possuem:

Metodo Descricao
collect(start, end, ...) Coleta dados do BCB
read(start, end, *, instituicao, ...) Le dados com filtros (start posicional, demais keyword-only)
list(columns, *, ...) Lista valores distintos para colunas (SELECT DISTINCT)
list_periodos() Periodos disponiveis
describe() Metadados do provider (inclui columns aceitas por list())
has_data() Verifica se tem dados

Metodos especificos:

Explorer Metodos Adicionais
cosif list_contas()
ifdata list_contas(), mapeamento()
cadastro search()

Limitacoes Conhecidas

  • Dependencia de APIs do BCB: a coleta depende da disponibilidade dos endpoints publicos do Banco Central. Se a API estiver fora do ar ou mudar seu schema, a coleta pode falhar.
  • Dados historicos: nem todos os periodos estao disponiveis para todas as fontes. Use list_periodos() para verificar disponibilidade.
  • Primeira coleta lenta: a coleta inicial de dados pode demorar dependendo do range de datas solicitado, pois faz multiplas requisicoes HTTP ao BCB (paralelas com 4 workers).
  • Cache sem invalidacao automatica: dados coletados ficam em cache local indefinidamente. Para atualizar, colete novamente o periodo desejado.
  • Sem suporte offline: a coleta requer conexao com a internet. A leitura funciona offline se os dados ja estiverem em cache.

Contribuindo

Contribuicoes sao bem-vindas! Consulte o guia de contribuicao para detalhes sobre como participar.

Licenca

Distribuido sob a licenca MIT. Veja LICENSE para mais informacoes.

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

ifdata_bcb-0.4.0.tar.gz (215.7 kB view details)

Uploaded Source

Built Distribution

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

ifdata_bcb-0.4.0-py3-none-any.whl (76.8 kB view details)

Uploaded Python 3

File details

Details for the file ifdata_bcb-0.4.0.tar.gz.

File metadata

  • Download URL: ifdata_bcb-0.4.0.tar.gz
  • Upload date:
  • Size: 215.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for ifdata_bcb-0.4.0.tar.gz
Algorithm Hash digest
SHA256 27a0f983f8c761246d40239deebe25c1eadd1092cc3a1213c992df1bfbef353e
MD5 6e6f050b8cef8d74fdbf99e130b6cb66
BLAKE2b-256 cebb620f0056b8ae1bb5712eb466e1555bc30b1b5990dbae91dfd04739f96b92

See more details on using hashes here.

Provenance

The following attestation bundles were made for ifdata_bcb-0.4.0.tar.gz:

Publisher: publish.yml on enzoomoreira/ifdata-bcb

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file ifdata_bcb-0.4.0-py3-none-any.whl.

File metadata

  • Download URL: ifdata_bcb-0.4.0-py3-none-any.whl
  • Upload date:
  • Size: 76.8 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for ifdata_bcb-0.4.0-py3-none-any.whl
Algorithm Hash digest
SHA256 c7f5a1fed6261d21cfb4acdd2a6c0c89045794200d8cb65559313b1c8017bfe4
MD5 122ecdadc85a1c1e9e7fd63b892ed380
BLAKE2b-256 6a4787f9c6ecdd7a4f91777a89fff719b1e610dc26caea1b4861d045ede97c95

See more details on using hashes here.

Provenance

The following attestation bundles were made for ifdata_bcb-0.4.0-py3-none-any.whl:

Publisher: publish.yml on enzoomoreira/ifdata-bcb

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

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