Pular para conteúdo

API BCB/SICOR

O modulo BCB fornece dados de credito rural do SICOR (Sistema de Operacoes do Credito Rural e do Proagro) do Banco Central do Brasil.

Funcoes

credito_rural

Dados de financiamento rural por produto, safra, UF e municipio, com dimensoes de programa, fonte de recurso, tipo de seguro, modalidade e atividade.

async def credito_rural(
    produto: str,
    safra: str | None = None,
    finalidade: str = "custeio",
    uf: str | None = None,
    agregacao: str = "municipio",
    programa: str | None = None,
    tipo_seguro: str | None = None,
    return_meta: bool = False,
) -> pd.DataFrame | tuple[pd.DataFrame, MetaInfo]

Parametros:

Parametro Tipo Descricao
produto str Produto (soja, milho, arroz, feijao, trigo, algodao, cafe, cana, sorgo)
safra str \| None Safra formato "2024/25". Default: safra mais recente
finalidade str "custeio", "investimento" ou "comercializacao"
uf str \| None Filtrar por UF (ex: "MT", "PR")
agregacao str "municipio" (default), "uf" ou "programa"
programa str \| None Filtrar por programa (ex: "Pronamp", "Pronaf")
tipo_seguro str \| None Filtrar por tipo de seguro (ex: "Proagro", "Seguro privado")
return_meta bool Se True, retorna tupla (DataFrame, MetaInfo)

Retorno:

DataFrame com colunas:

Coluna Tipo Descricao
safra str Safra "2024/2025"
ano_emissao int Ano de emissao
mes_emissao int Mes de emissao
uf str UF do municipio
municipio str Nome do municipio
produto str Produto financiado
finalidade str Finalidade (custeio, investimento, comercializacao)
valor float Valor financiado (R$)
area_financiada float Area financiada (ha)
qtd_contratos int Quantidade de contratos
cd_programa str Codigo do programa SICOR
programa str Nome do programa (ex: "Pronamp", "Pronaf")
cd_sub_programa str Codigo do sub-programa
cd_fonte_recurso str Codigo da fonte de recurso
fonte_recurso str Nome da fonte (ex: "LCA", "FNE", "Poupanca rural controlados")
cd_tipo_seguro str Codigo do tipo de seguro
tipo_seguro str Nome do seguro (ex: "Proagro", "Seguro privado")
cd_modalidade str Codigo da modalidade
modalidade str Nome da modalidade (ex: "Individual", "Coletiva")
cd_atividade str Codigo da atividade
atividade str Nome da atividade (ex: "Agricola", "Pecuaria")
regiao str Regiao (ex: "SUL", "CENTRO-OESTE")

Exemplo:

from agrobr import bcb

# Credito custeio soja MT
df = await bcb.credito_rural("soja", safra="2024/25", uf="MT")

# Agregado por UF
df = await bcb.credito_rural("milho", agregacao="uf")

# Agregado por programa
df = await bcb.credito_rural("soja", safra="2024/25", agregacao="programa")

# Filtrar por programa
df = await bcb.credito_rural("soja", safra="2024/25", programa="Pronamp")

# Filtrar por tipo de seguro
df = await bcb.credito_rural("soja", safra="2024/25", tipo_seguro="Proagro")

# Com metadados
df, meta = await bcb.credito_rural("soja", return_meta=True)
print(meta.schema_version)  # "1.1"

Dimensoes SICOR

As dimensoes sao enriquecidas automaticamente pelo parser com dicionarios hardcoded. Codigos desconhecidos geram "Desconhecido ({code})" com log warning.

Dimensao Codigos conhecidos
Programa Pronaf, Pronamp, Funcafe, Moderfrota, ABC, Inovagro, etc.
Fonte de recurso Recursos obrigatorios, Poupanca rural, LCA, FNO/FNE/FCO, Funcafe, etc.
Tipo de seguro Proagro, Sem seguro, Seguro privado, Nao se aplica
Modalidade Individual, Coletiva
Atividade Agricola, Pecuaria

Versao Sincrona

from agrobr.sync import bcb

df = bcb.credito_rural("soja", safra="2024/25")
df = bcb.credito_rural("soja", safra="2024/25", programa="Pronamp")

Fallback

Quando a API OData do BCB falha, o agrobr usa automaticamente BigQuery (Base dos Dados) como fallback. Requer pip install agrobr[bigquery].

Notas

  • Fonte: BCB/SICOR — licenca livre
  • Dados disponiveis a partir de 2013
  • Contract v1.1 — 11 novas colunas nullable desde v0.10.1