uso de funções csv.DictReader() e csv.DictWriter() para ler e escrever ficheiros csv

This commit is contained in:
2024-05-19 10:24:29 +01:00
parent b95f0c2b79
commit 6ab144e3d1
6 changed files with 281 additions and 16 deletions

61
portfolio.py Normal file
View File

@ -0,0 +1,61 @@
# script para criar um historico de preços de criptomoedas, guardado em ficheiro CSV, com intuito de utilizar este historico de precos para acompanhar evolução de portfolio de criptomoedas
# aceder ao historico de preços OHLC de CoinGecko através da API
# máximo de requests mensal: 10000 (320/dia; 13/hora)
# . referenciar o uso da CoinGecko através de branding oficial e link para site (https://www.coingecko.com/en/branding)
# . documentação API: https://docs.coingecko.com/v3.0.1/reference/introduction
# . obter OHLC: https://docs.coingecko.com/v3.0.1/reference/coins-id-ohlc
import requests
url_raiz_API = 'https://api.coingecko.com/api/v3/'
criptomoeda = 'bitcoin'
vs_currency = 'eur'
dias = '30'
precisao = '3'
url_consulta_ohlc = 'coins/' + criptomoeda + '/ohlc?vs_currency=' + vs_currency + '&days=' + dias + '&precision=' + precisao
url = url_raiz_API + url_consulta_ohlc
CHAVE_API = 'CG-K5RS5VXsdFDip2UvY3z8VjQP'
headers = {
'accept': 'application/json',
'x-cg-demo-api-key': CHAVE_API
}
resposta = requests.get(url, headers= headers)
# carregar dados já existentes em ficheiro CSV (criar ficheiro se não existir)
import csv
import os
cabecalho: list = [ 'data_unix', 'criptomoeda', 'vs_currency', 'preco_abertura', 'preco_maximo', 'preco_minimo', 'preco_fecho' ]
caminho_ficheiro_csv_historico_bitcoin = './historico_precos.csv'
if (os.path.exists(caminho_ficheiro_csv_historico_bitcoin) == False):
ficheiro = open(caminho_ficheiro_csv_historico_bitcoin, 'w+', newline='')
ficheiroCSV = csv.DictWriter(ficheiro, fieldnames=cabecalho)
ficheiroCSV.writeheader()
ficheiro.close()
with open(caminho_ficheiro_csv_historico_bitcoin, 'r', newline='') as ficheiro_csv_historico_precos:
ficheiroCSV = csv.DictReader(ficheiro_csv_historico_precos)
entradas: list = []
for linha in ficheiroCSV:
entradas.append(linha)
# converter dados de coingecko para o formato usado no ficheiro CSV
novas_linhas: list = []
for linha_resposta in resposta.json():
nova_entrada: dict = {}
nova_entrada[cabecalho[0]] = linha_resposta[0]
nova_entrada[cabecalho[1]] = criptomoeda
nova_entrada[cabecalho[2]] = vs_currency
nova_entrada[cabecalho[3]] = linha_resposta[1]
nova_entrada[cabecalho[4]] = linha_resposta[2]
nova_entrada[cabecalho[5]] = linha_resposta[3]
nova_entrada[cabecalho[6]] = linha_resposta[4]
novas_linhas.append(nova_entrada)
# eliminar registos que não sejam novos
# gravar dados importados
with open(caminho_ficheiro_csv_historico_bitcoin, 'w+', newline='') as ficheiro_csv_historico_precos:
ficheiroCSV = csv.DictWriter(ficheiro_csv_historico_precos, fieldnames=cabecalho)
ficheiroCSV.writeheader()
ficheiroCSV.writerows(entradas)