adicionada chamada api 'coin_historical_chart_data_within_time_range_by_id()'

This commit is contained in:
2024-06-13 15:19:27 +01:00
parent ef84c90bc8
commit 8b9817dca0
2 changed files with 65 additions and 7 deletions

View File

@ -128,7 +128,7 @@ quando houver parametros 'vazios' passados como argumentos, estes não devem ser
* ✅ coin historical chart data by id
* ❌⬛ coin historical chart data within time range by id
* coin historical chart data within time range by id
* ❌⬛ coin ohlc chart by id
* **contract**

View File

@ -692,17 +692,75 @@ def coin_historical_chart_data_by_id(
# print(f'erro {codigo}: {dados}')
def coin_historical_chart_data_within_time_range_by_id() -> tuple:
pass
# temos de criar outra abordagem, este noma de chamada api é enorme...
def coin_historical_chart_data_within_time_range_by_id(
id_criptomoeda: str = '',
vs_currency: str = '',
from_unix: int = -1,
to_unix: int = -1,
precision: str | int = 'full'
) -> tuple:
'''https://docs.coingecko.com/v3.0.1/reference/coins-id-market-chart-range
este endpoint permite obter dados historicos graficos compreendidos num periodo de tempo
unix com preco, capitalizacao de mercado e volume 24hrs a partir de um id de moeda
'''
# dicionario parametros
api_parameters = {
'id': '',
'vs_currency': '',
'from': '',
'to': '',
'precision': '',
}
# validacao parametros
# id_criptomoeda (como 'id' é nome reservado, foi usado outro nome)
if not isinstance(id_criptomoeda, str):
raise TypeError('\'id_criptomoeda\' tem de ser do tipo \'str\'')
if id_criptomoeda == '':
raise ValueError('\'id_criptomoeda\' tem de ser definido')
api_parameters['id'] = id_criptomoeda
# vs_currency
if not isinstance(vs_currency, str):
raise TypeError('\'vs_currency\' tem de ser do tipo \'str\'')
if vs_currency == '':
raise ValueError('\'vs_currency\' tem de ser definido')
api_parameters['vs_currency'] = vs_currency
# from_unix (como 'from' é nome reservado, foi usado outro nome)
if not isinstance(from_unix, int):
raise TypeError('\'from_unix\' tem de ser do tipo \'int\'')
if from_unix == -1:
raise ValueError('\'from_unix\' tm de ser definido')
api_parameters['from'] = str(from_unix)
# to_unix ('to' não é nome reservado, mas foi usado este nome para manter relação)
if not isinstance(to_unix, int):
raise TypeError('\'to_unix\' tem de ser do tipo \'int\'')
if to_unix == -1:
raise ValueError('\'to_unix\' tem de ser definido')
api_parameters['to'] = str(to_unix)
# precision
if not isinstance(precision, (int, str)):
raise TypeError('\'precision\' tem de ser do tipo \'(int, str)\'')
if isinstance(precision, str):
if precision == 'full':
precision = '18'
precision = int(precision)
if isinstance(precision, int):
if precision < 0:
precision = 0
if precision > 18:
precision = 18
api_parameters['precision'] = str(precision)
return API(f'coins/{api_parameters['id']}/market_chart/range', api_parameters)
# debug (decomentar linhas seguintes para testar funcao)
# url, codigo, dados = coins_list_with_market_data('eur', 'bitcoin')
# url, codigo, dados = coin_historical_chart_data_within_time_range_by_id('bitcoin','eur',1711929600,1712275200)
# print(f'url: {url}')
# if codigo == 200:
# print(f'codigo: {codigo}')
# for item in dados:
# print(item)
# print(f'{item}: {dados[item]}')
# else:
# print(f'erro {codigo}: {dados}')