Added option to cache prices
This commit is contained in:
@@ -8,7 +8,7 @@ from EngieApi.EngieAPI import EngieAPI
|
|||||||
|
|
||||||
|
|
||||||
class Dynamic:
|
class Dynamic:
|
||||||
def __init__(self, btw=1.21):
|
def __init__(self, btw=1.21, cache: bool = False):
|
||||||
self.btw = btw
|
self.btw = btw
|
||||||
self.vast = 100.7 # EUR / jaar
|
self.vast = 100.7 # EUR / jaar
|
||||||
|
|
||||||
@@ -22,6 +22,7 @@ class Dynamic:
|
|||||||
# 20000 < kwh < 50000: 1.22748 cent / kWh
|
# 20000 < kwh < 50000: 1.22748 cent / kWh
|
||||||
# 50000 < kwh < 100000: 1.15540 cent / kWh
|
# 50000 < kwh < 100000: 1.15540 cent / kWh
|
||||||
self.federale_accijns = 0.0144160 # EUR / kWh
|
self.federale_accijns = 0.0144160 # EUR / kWh
|
||||||
|
self.cache = cache
|
||||||
|
|
||||||
def calculate_price_per_kwh(self, date, peak: float):
|
def calculate_price_per_kwh(self, date, peak: float):
|
||||||
"""calculate_price_per_kwh
|
"""calculate_price_per_kwh
|
||||||
@@ -29,7 +30,7 @@ class Dynamic:
|
|||||||
:param date: date to calculate for
|
:param date: date to calculate for
|
||||||
:type date: date
|
:type date: date
|
||||||
"""
|
"""
|
||||||
api = EngieAPI()
|
api = EngieAPI(cache=self.cache)
|
||||||
epex_spot = np.array(api.get_epex_spot(date))
|
epex_spot = np.array(api.get_epex_spot(date))
|
||||||
|
|
||||||
prijs = 0.2040 + 0.1 * (epex_spot) # zonder BTW per Cent/kWh
|
prijs = 0.2040 + 0.1 * (epex_spot) # zonder BTW per Cent/kWh
|
||||||
|
|||||||
@@ -8,7 +8,7 @@ date_format = "%Y-%m-%dT%H:%M:%S%z"
|
|||||||
|
|
||||||
|
|
||||||
class EngieAPI:
|
class EngieAPI:
|
||||||
def __init__(self):
|
def __init__(self, cache: bool = False):
|
||||||
self.url = "https://benergy-back.azurewebsites.net/api/gateway/mercure"
|
self.url = "https://benergy-back.azurewebsites.net/api/gateway/mercure"
|
||||||
self.headers = {
|
self.headers = {
|
||||||
"Host": "benergy-back.azurewebsites.net",
|
"Host": "benergy-back.azurewebsites.net",
|
||||||
@@ -22,7 +22,21 @@ class EngieAPI:
|
|||||||
"Accept-Language": "en-GB,en;q=0.9",
|
"Accept-Language": "en-GB,en;q=0.9",
|
||||||
}
|
}
|
||||||
|
|
||||||
|
self.cache = cache
|
||||||
|
self.cache_file = "EngieCache.json"
|
||||||
|
|
||||||
def get_epex_spot(self, date: date) -> List[float]:
|
def get_epex_spot(self, date: date) -> List[float]:
|
||||||
|
if self.cache:
|
||||||
|
try:
|
||||||
|
with open("EngieCache.json", "r") as f:
|
||||||
|
cache = json.load(f)
|
||||||
|
print(cache)
|
||||||
|
except FileNotFoundError:
|
||||||
|
cache = {}
|
||||||
|
|
||||||
|
if date.strftime("%Y-%m-%d") in cache:
|
||||||
|
return cache[date.strftime("%Y-%m-%d")]
|
||||||
|
|
||||||
to_date = datetime(date.year, date.month, date.day, 23, 59, 59)
|
to_date = datetime(date.year, date.month, date.day, 23, 59, 59)
|
||||||
from_date = to_date - timedelta(days=1, hours=23, minutes=59, seconds=59)
|
from_date = to_date - timedelta(days=1, hours=23, minutes=59, seconds=59)
|
||||||
|
|
||||||
@@ -40,10 +54,27 @@ class EngieAPI:
|
|||||||
|
|
||||||
values = []
|
values = []
|
||||||
for j in res.json()[0]["Points"]:
|
for j in res.json()[0]["Points"]:
|
||||||
|
print(j)
|
||||||
# check if the Date is the same as the one requested, attention to the timezone
|
# check if the Date is the same as the one requested, attention to the timezone
|
||||||
if datetime.strptime(j["Date"], date_format).date() == date:
|
if datetime.strptime(j["Date"], date_format).date().strftime(
|
||||||
|
"%Y-%m-%d"
|
||||||
|
) == date.strftime("%Y-%m-%d"):
|
||||||
values.append(j["Value"])
|
values.append(j["Value"])
|
||||||
|
|
||||||
|
if self.cache:
|
||||||
|
# check if the cache exists else create it
|
||||||
|
try:
|
||||||
|
with open("EngieCache.json", "r") as f:
|
||||||
|
cache = json.load(f)
|
||||||
|
except FileNotFoundError:
|
||||||
|
cache = {}
|
||||||
|
|
||||||
|
# update cache
|
||||||
|
cache[date.strftime("%Y-%m-%d")] = values
|
||||||
|
|
||||||
|
with open("EngieCache.json", "w+") as f:
|
||||||
|
json.dump(cache, f)
|
||||||
|
|
||||||
if not values:
|
if not values:
|
||||||
raise ValueError("No data found for this date")
|
raise ValueError("No data found for this date")
|
||||||
return values
|
return values
|
||||||
|
|||||||
Reference in New Issue
Block a user