{"id":20426135,"url":"https://github.com/tonsatomicos/bacen-currency-api-integration","last_synced_at":"2025-04-12T19:06:30.223Z","repository":{"id":229906426,"uuid":"777514553","full_name":"tonsatomicos/bacen-currency-api-integration","owner":"tonsatomicos","description":" Estudo independente: extração, processamento e persistência de dados da API do Banco Central do Brasil (PTAX) com Python.","archived":false,"fork":false,"pushed_at":"2024-05-12T22:26:41.000Z","size":527,"stargazers_count":3,"open_issues_count":0,"forks_count":1,"subscribers_count":1,"default_branch":"main","last_synced_at":"2024-05-13T22:27:07.817Z","etag":null,"topics":["docker","postgresql","python","requests"],"latest_commit_sha":null,"homepage":"","language":"Jupyter Notebook","has_issues":true,"has_wiki":null,"has_pages":null,"mirror_url":null,"source_name":null,"license":null,"status":null,"scm":"git","pull_requests_enabled":true,"icon_url":"https://github.com/tonsatomicos.png","metadata":{"files":{"readme":"README.md","changelog":null,"contributing":null,"funding":null,"license":null,"code_of_conduct":null,"threat_model":null,"audit":null,"citation":null,"codeowners":null,"security":null,"support":null,"governance":null,"roadmap":null,"authors":null,"dei":null,"publiccode":null,"codemeta":null}},"created_at":"2024-03-26T01:45:11.000Z","updated_at":"2024-05-13T22:27:07.819Z","dependencies_parsed_at":"2024-03-29T22:28:43.421Z","dependency_job_id":"6497cf22-63c6-44a1-8bd5-b12ac9da716a","html_url":"https://github.com/tonsatomicos/bacen-currency-api-integration","commit_stats":null,"previous_names":["tonsatomicos/dpp-ptax-bacen","tonsatomicos/bacen-ptax-data-processing","tonsatomicos/bacen-currency-api-integration"],"tags_count":0,"template":false,"template_full_name":null,"repository_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/tonsatomicos%2Fbacen-currency-api-integration","tags_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/tonsatomicos%2Fbacen-currency-api-integration/tags","releases_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/tonsatomicos%2Fbacen-currency-api-integration/releases","manifests_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/tonsatomicos%2Fbacen-currency-api-integration/manifests","owner_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners/tonsatomicos","download_url":"https://codeload.github.com/tonsatomicos/bacen-currency-api-integration/tar.gz/refs/heads/main","host":{"name":"GitHub","url":"https://github.com","kind":"github","repositories_count":224742353,"owners_count":17362232,"icon_url":"https://github.com/github.png","version":null,"created_at":"2022-05-30T11:31:42.601Z","updated_at":"2022-07-04T15:15:14.044Z","host_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub","repositories_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories","repository_names_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repository_names","owners_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners"}},"keywords":["docker","postgresql","python","requests"],"created_at":"2024-11-15T07:15:34.933Z","updated_at":"2024-11-15T07:15:35.684Z","avatar_url":"https://github.com/tonsatomicos.png","language":"Jupyter Notebook","funding_links":[],"categories":[],"sub_categories":[],"readme":"# \u003cp align=\"center\"\u003eProjeto de Processamento de Dados\u003cbr\u003eBacen - PTAX\u003c/p\u003e\n\n\u003cp align=\"center\"\u003e\n\u003cimg src=\"http://img.shields.io/static/v1?label=LICENCA\u0026message=...\u0026color=GREEN\u0026style=for-the-badge\"/\u003e     \n\u003cimg src=\"http://img.shields.io/static/v1?label=STATUS\u0026message=N/A\u0026color=GREEN\u0026style=for-the-badge\"/\u003e\n\u003c/p\u003e\n\nEste projeto envolve o desenvolvimento de uma solução em Python para acessar e consumir a API do Banco Central, obtendo os valores de fechamento de venda e compra de cotação de moedas estrangeiras. \n\nUtilizando a biblioteca requests para fazer as requisições HTTP e o Docker com PostgreSQL para armazenar os dados, buscando facilitar o acesso e análise dessas informações de forma direta e eficiente.\n\n## Projeto\n\n![Diagram](https://github.com/tonsatomicos/bacen-ptax-data-processing/blob/main/assets/diagram_pipeline.png?raw=true)\n\nSinta-se à vontade para clonar, adaptar e ajustar o projeto conforme necessário. Consulte as instruções abaixo, se precisar. :alien:\n\n## Dependências do Projeto\n\nEste projeto foi desenvolvido utilizando o Poetry + Pyenv para gerenciamento de ambientes virtuais e bibliotecas.\n\n### Bibliotecas Utilizadas\n\n- pandas = \"^2.2.1\"\n- requests = \"^2.31.0\"\n- sqlalchemy = \"^2.0.29\"\n- psycopg2 = \"^2.9.9\"\n\n### Instalação das Dependências\n\nVocê pode instalar as dependências manualmente, ou, utilizando o Poetry ou o Pip com os seguintes comandos:\n\n#### Utilizando Poetry\n\n```bash\npoetry install\n\n```\n\n#### Utilizando Pip\n\n```bash\npip install -r requirements.txt\n\n```\n\n## Configurações do Projeto\n\nUtilizando PostgreSQL para persistência de dados, porém você tem a liberdade de optar por outras bases de dados. No entanto, caso escolha o PostgreSQL, sinta-se à vontade para seguir o guia abaixo.\n\n### Banco de dados PostgreSQL\n\nVocê pode escolher entre utilizar o Docker para subir um banco PostgreSQL ou instalar de outras maneiras.\n\n#### Utilizando Docker\n\n\u003cpre\u003e\u003ccode\u003edocker-compose up -d\u003c/code\u003e\u003c/pre\u003e\n\n#### Outras maneiras\n\nSegue tutorial aleatório da **\u003ca href=\"https://youtu.be/L_2l8XTCPAE?si=-OJ21qv_48BgHFq2\"\u003eHashtag Treinamentos\u003c/a\u003e**. \u003cbr\u003eScript de criação da tabela disponibilizado em \u003ccode\u003esrc/sql\u003c/code\u003e.\n\n### Conclusão\n\nLembre-se sempre de verificar o usuário, senha, base, porta e tabela. Configurado logo após o início da  função \u003ccode\u003emain\u003c/code\u003e, altere se necessário.\n\n\u003cpre\u003e\u003ccode\u003e    start_date = '02-01-2016'\n    end_date = '04-01-2024'\n    coin = 'EUR' # or USD\n    dbuser = 'teste'\n    dbpass = 'teste'\n    dbname = 'teste_db'\n    dblocal = 'localhost:5437'\n    dbtable = 'public.ptax'\u003c/code\u003e\u003c/pre\u003e\n\nIsso irá garantir que as informações sejam persistidas no banco de dados PostgreSQL.\u003c/p\u003e\n\n\n## Considerações Finais\n- A documentação pode não estar tão detalhada; talvez seja necessário um certo nível de conhecimento para adaptar o código.\n- Se tudo estiver configurado corretamente, basta executa o script e verificar a tabela no banco de dados usando pgAdmin ou DBeaver.\n- Com esse projeto, conseguimos facilmente persistir informações de diversos tipos de moedas, contanto que estejam disponíveis na \u003ca href=\"https://olinda.bcb.gov.br/olinda/servico/PTAX/versao/v1/aplicacao#!/recursos/Moedas#eyJmb3JtdWxhcmlvIjp7IiRmb3JtYXQiOiJqc29uIiwiJHRvcCI6MTAwfSwicHJvcHJpZWRhZGVzIjpbMCwxLDJdLCJwZXNxdWlzYWRvIjp0cnVlLCJhY3RpdmVUYWIiOiJ0YWJsZSIsImdyaWRTdGF0ZSI6ewMwAzpbewNCAyIEMAQiLANBA30sewNCAyIEMQQiLANBA30sewNCAyIEMgQiLANBA31dLAMxAzp7fSwDMgM6W10sAzMDOnt9LAM0Azp7fSwDNQM6e319LCJwaXZvdE9wdGlvbnMiOnsDYQM6e30sA2IDOltdLANjAzo1MDAsA2QDOltdLANlAzpbXSwDZgM6W10sA2cDOiJrZXlfYV90b196IiwDaAM6ImtleV9hX3RvX3oiLANpAzp7fSwDagM6e30sA2sDOjg1LANsAzpmYWxzZSwDbQM6e30sA24DOnt9LANvAzoiQ29udGFnZW0iLANwAzoiVGFibGUifX0=\"\u003ebase de dados\u003c/a\u003e do Banco Central do Brasil (BACEN).\n- Disponibilizado um arquivo ipynb em \u003ccode\u003esrc/data_analysis\u003c/code\u003e com alguns insights.\n\n\u003chr\u003e\n\n![Image](https://i.imgur.com/p4vnGAN.gif)\n","project_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Ftonsatomicos%2Fbacen-currency-api-integration","html_url":"https://awesome.ecosyste.ms/projects/github.com%2Ftonsatomicos%2Fbacen-currency-api-integration","lists_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Ftonsatomicos%2Fbacen-currency-api-integration/lists"}