Я дам вам кое-что для начала;Поместите его в класс, который возвращает dict, заполненный данными (также может быть простой функцией)
import requests
class CryptoData:
def __init__(self):
self.usd_url = "https://api.coingecko.com/api/v3/coins/markets?" \
"vs_currency=usd&order=market_cap_desc&per_page=250&page=1" \
"&sparkline=false&price_change_percentage=24h"
self.gbp_url = "https://api.coingecko.com/api/v3/coins/markets?" \
"vs_currency=gbp&order=market_cap_desc&per_page=250&page=1" \
"&sparkline=false&price_change_percentage=24h"
def get_crypto_data_dict(self, get_it=False):
crypto_dict = dict()
requests1 = requests.get(self.usd_url)
results1 = requests1.json()
requests2 = requests.get(self.gbp_url)
results2 = requests2.json()
for i in range(0, 250):
crypto_dict[results1[i]['id']] = {
'coin_name': results1[i]['name'],
'changes': results1[i]['price_change_percentage_24h'],
'usd': results1[i]['current_price'],
'gbp': results2[i]['current_price']
}
return crypto_dict
Затем в поле зрения:
def crypt_view(request):
crypto_data = CryptoData()
context = {
'crypto_data': crypto_data.get_crypto_data_dict()
}
return render(request, 'crypto/crypto.html', context=context)
Затем в crypto.html (это просто пример):
<ul>
{% for crypto_datum, crypto_value in crypto_data.items %}
<li>{{ crypto_datum }}
<ul>
{% for info, value in crypto_value.items %}
<li>{{ info }}: {{ value }}</li>
{% endfor %}
</ul>
</li>
{% endfor %}
</ul>
Одна проблема с этим: всякий раз, когда кто-то касается веб-страницы, вы автоматически отправляете запрос на получение в coingecko.Это может быть проблемой с ограничениями скорости
, так что вы можете создать экземпляр CryptoData в views.py, но за пределами вашей функции просмотра.
так что лучшая реализация, которая может ограничивать обновление данных каждые 60 секунд, такова:
import requests, time
from django.shortcuts import render
class CryptoData:
def __init__(self):
self.usd_url = "https://api.coingecko.com/api/v3/coins/markets?" \
"vs_currency=usd&order=market_cap_desc&per_page=250&page=1" \
"&sparkline=false&price_change_percentage=24h"
self.gbp_url = "https://api.coingecko.com/api/v3/coins/markets?" \
"vs_currency=gbp&order=market_cap_desc&per_page=250&page=1" \
"&sparkline=false&price_change_percentage=24h"
self.previous_request = None
self.crypto_dict = dict()
def get_crypto_data_dict(self, seconds_to_wait=60):
if not self.previous_request or self.previous_request+seconds_to_wait < time.time():
print("requested", self.previous_request, time.time())
self.previous_request = time.time()
crypto_dict = dict()
requests1 = requests.get(self.usd_url)
results1 = requests1.json()
requests2 = requests.get(self.gbp_url)
results2 = requests2.json()
for i in range(0, 250):
self.crypto_dict[results1[i]['id']] = {
'coin_name': results1[i]['name'],
'changes': results1[i]['price_change_percentage_24h'],
'usd': results1[i]['current_price'],
'gbp': results2[i]['current_price']
}
return self.crypto_dict
crypto_data = CryptoData()
def crypt_view(request):
context = {
'crypto_data': crypto_data.get_crypto_data_dict()
}
return render(request, 'crypto/crypto.html', context=context)
В этой реализации coingecko api вызывается только каждые 60 секунд
РЕДАКТИРОВАТЬ: для отображения так же, как вы могли бы сделать что-то вроде этого:
{% for crypto_datum, crypto_values in crypto_data.items %}
<div>
<p>Coin ID: {{ crypto_datum }}<br>
Coin Name: {{ crypto_datum|capfirst }}<br>
Price per coin in USD: ${{ crypto_values.usd|floatformat:2 }}<br>
Price Per coin in GBP: £{{ crypto_values.gbp|floatformat:2 }}<br>
Percentage price change: {{ crypto_values.changes|floatformat:2 }}%
</p>
</div>
{% endfor %}
Это будет выглядеть примерно так:
Coin ID: bitcoin
Coin Name: Bitcoin
Price per coin in USD: $3466.24
Price Per coin in GBP: £2657.72
Percentage price change: 0.16%
Coin ID: ripple
Coin Name: Ripple
Price per coin in USD: $0.30
Price Per coin in GBP: £0.23
Percentage price change: -0.85%
Coin ID: ethereum
Coin Name: Ethereum
Price per coin in USD: $107.27
Price Per coin in GBP: £82.25
Percentage price change: -0.11%