Plano de Dados Abertos do Banco Central do Brasil
Maio/2023 – Abril/2025
A Política de Dados Abertos do Poder Executivo Federal foi instituída pelo Decreto nº 8.777, de 11 de maio de 2016, e tem por objetivo a disponibilização na internet – por parte de órgãos e entidades da administração pública federal direta, autárquica e fundacional – de dados e informações acessíveis ao público que possam ser livremente lidos por máquina, usados, cruzados e reutilizados, fomentando-se o controle social, o desenvolvimento tecnológico, o aprimoramento da cultura de transparência pública e a inovação nos diversos setores da sociedade. Atendendo ao disposto no referido Decreto, o Ouvidor, na qualidade de autoridade de monitoramento da LAI, foi designado para atuar no monitoramento da implementação do Plano de Dados Abertos do Banco Central do Brasil (PDA/BC).
O Plano de Dados Abertos do Banco Central do Brasil (PDA/BC) estabelece o modelo de governança, diretrizes e orientações estratégicas e operacionais para ações de contínua ampliação e aprimoramento da transparência das informações produzidas pela Autarquia, particularmente pela publicação de bases de dados em formatos abertos, nos casos em que não haja vedação expressa de acesso, cobrindo sua expansão, aprofundamento, aperfeiçoamentos e divulgação, de modo a inclusive permitir a reutilização dos dados públicos pela sociedade.
Desde a edição do primeiro PDA/BC, em 2016, cabe ressaltar a criação do Portal de Dados Abertos, a realização de concurso de aplicativos, a participação em eventos de divulgação, a exemplo da Campus Party, além da própria vanguarda na disponibilização de dados em formato aberto entre os órgãos no governo federal. Em 11 de abril de 2023 o BC disponibilizava 3.706 bases de dados no Portal Brasileiro de Dados Abertos, o que representava 30,2% do total de bases disponibilizados por todos os órgãos do poder público (12.275).
A priorização da disponibilização dos conjuntos de dados pelo BC busca considerar o grau de demanda potencial das informações como um critério fundamental, respeitando-se evidentemente os dispositivos legais e regulamentares e o alinhamento estratégico da Instituição. O BC identifica o potencial das informações a serem disponibilizadas no Portal por meio, em especial, de: (1) consultas públicas1 efetuada via pesquisas junto à sociedade em geral e também junto ao Conselho de Usuários, (2) mapeamento das demandas recepcionadas ao amparo da LAI e via “Fala BR3 ”, (3) identificação de bases mais acessadas no site, e (4) levantamento realizado junto aos curadores das bases de dados.
Texto extraído do Plano de Dados Abertos do Banco Central do Brasil – Maio/2023 – Abril/2025, acessado de https://www.bcb.gov.br/content/acessoinformacao/acesso_informacao_docs/Plano_Dados_Abertos_BC_mai2023-abr2025.pdf
A biblioteca python-bcb
O python-bcb é uma interface em Pynthon é uma iniciativa derivada do projeto de Dados Abertos do Banco Central do Brasil estruturada para obter informações da API de dados abertos da própria instituição. Por meio do python-bcb, pode o programador acessar dados de moedas, taxas de juros, índices de preços e informações de instituições financeiras, entre outros dados disponíveis.
A seguir, vê-se como usar a API do Banco Central para recuperar dados da SELIC entre 01/01/2021 e 31/12/2023 para plotar um gráfico de linhas.
1 def CarregaSELIC(data_inicial, data_final):
2 url_BASEN = "http://api.bcb.gov.br/dados/serie/"
3 url_BASEN = url_BASEN + "bcdata.sgs.4189/dados?formato="
4 url_BASEN = url_BASEN + f&"{&dataInicial={data_inicial}&dataFinal={data_final}"
4 serie_SELIC = pd.read_csv(url_BASEN, sep=";")
6 return serie_SELIC
7
8 serie = CarregaSELIC("01/01/2021", "31/12/2023")
9 serie = serie.replace({',': '.'}, regex=True)
10 serie['valor'] = serie['valor'].astype(float)
11 serie.plot.line(x = "data", y = "valor", title = "SELIC durante 2023", legend = False)
12 plot.show(block = True)
Os dados de serie podem ser usados como parâmetros de funções, como pode ser observado no fragmento (incompleto) de código a seguir:
29 def inserir_registros_mysql(serie, nome_tabela, conexao):
30
31 # Criar a tabela se ela não existir
32 criar_tabela_sql = ""
33 conexao.execute(criar_tabela_sql)
34 # Inserir os registros na tabela
35 inserir_sql = ""
36 for index, row in serie.iterrows():
Considerando o caráter motivador do texto apresentado e utilizando as informações presentes nos códigos-fonte Python apresentados e sem utilizar bibliotecas e funções adicionais da linguagem, discorra sobre:
- O conceito de biblioteca e o procedimento a ser seguido para utilizar a biblioteca utilizar funções da biblioteca python-bcb no código-fonte. [valor: 8,00 pontos]
- O tipo da variável url_BACEN, utilizada entre as linhas 02 e 05, e a finalidade do caractere f imediatamente após o operador de atribuição. [valor: 8,00 pontos]
- O tipo de dados serie_SELIC, inicializada na linha 05 e utilizada como retorno da função CarregaSELIC, na linha 06. [valor: 8,00 pontos]
- O conceito de média aritmética e implemente uma função para determinar a média aritmética das taxas SELIC recuperadas por CarregaSELIC. (7,50 pontos)
- O conceito de variância e implemente uma função para determinar a variância das taxas SELIC recuperadas por CarregaSELIC. [valor: 8,00 pontos]
- Como deve ser completada a implementada a função inserir_registros_mtsql (X, nome_tabela, conexão) para inserir os dados de do DataFrame X na tabela nome_tabela do banco de dados acessado por conexão. [valor: 8,00 pontos]
CONTEÚDO EXCLUSIVO
Confira nossos planos especiais de assinatura e desbloqueie agora!
CONTEÚDO EXCLUSIVO
Confira nossos planos especiais de assinatura e desbloqueie agora!
Ops! Esta questão ainda não tem resolução em vídeo.
Questões Relacionadas
O intercâmbio de dados entre aplicações é o processo de transmitir e receber informações entre sistemas distintos, permitindo que eles operem em conjunto e compartilhem dados de forma integrada. Esse processo é essencial em cenários onde diferentes aplicações precisam colaborar para fornecer uma experiência coesa ou uma visão unificada dos dados.
Dois dos principais formatos de dados utilizados atualmente são JSON (JavaScript Object Notation), formato leve e fácil de ler, amplamente usado em APIs RESTful; e o XML (Extensible Markup Language), mais verboso que o JSON, mas permite esquemas complexos, sendo comum em Web Services SOAP.
A seguir, é apresentado um fragmento de código em XML:
<p…
O intercâmbio de dados entre aplicações é o processo de transmitir e receber informações entre sistemas distintos, permitindo que eles operem em conjunto e compartilhem dados de forma integrada. Esse processo é essencial em cenários onde diferentes aplicações precisam colaborar para fornecer uma experiência coesa ou uma visão unificada dos dados.
Dois dos principais formatos de dados utilizados atualmente são JSON (JavaScript Object Notation), formato leve e fácil de ler, amplamente usado em APIs RESTful; e o XML (Extensible Markup Language), mais verboso que o JSON, mas permite esquemas complexos, sendo comum em Web Services SOAP.
A seguir, é apresentado um fragmento de código em XML:
<p…
Java é uma linguagem de programação de alto nível e orientada a objetos que foi desenvolvida pela Sun Microsystems (agora propriedade da Oracle Corporation) na década de 1990 e foi projetada para ser portátil, eficiente e segura, permitindo que o código desenvolvido seja executado em diferentes plataformas sem a necessidade de recompilação.
A seguir, é apresentado o código fonte de uma classe escrita em JAVA, em que pode ser estabelecida a conexão com o banco de dados database utilizando a porta port, localizado em hostname:
public class MySQL extends Database {
private String port;
private String hostname;
public MySQL (String database, String hostname, String port) {
super(database);
this.…



