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.1.tar.gz (215.8 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.1-py3-none-any.whl (77.1 kB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: ifdata_bcb-0.4.1.tar.gz
  • Upload date:
  • Size: 215.8 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.1.tar.gz
Algorithm Hash digest
SHA256 94615aaa715c164371a6660aed83d0520285932da8fd6f9077785c5c7968be74
MD5 de00813194f05fed9dd4e921b0f370ec
BLAKE2b-256 842d1bf04b483de6b1f82b7ee63b9ae3e1031bc436f3d3186cc1d60e07c4a1dc

See more details on using hashes here.

Provenance

The following attestation bundles were made for ifdata_bcb-0.4.1.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.1-py3-none-any.whl.

File metadata

  • Download URL: ifdata_bcb-0.4.1-py3-none-any.whl
  • Upload date:
  • Size: 77.1 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.1-py3-none-any.whl
Algorithm Hash digest
SHA256 0d8f660dbf7085eedccaf13d4b1b9bff976c9d7e2fe9dce1c80491d72290862e
MD5 5a4afc023099ac58dcec9dc3b738ec4e
BLAKE2b-256 3dfdcd748d678810e5b87226ed812d1147dd4a052d481bedc85ee9a2e45fbf8d

See more details on using hashes here.

Provenance

The following attestation bundles were made for ifdata_bcb-0.4.1-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