aboutsummaryrefslogtreecommitdiffstats
path: root/elvia_gridtariff2pgsql.py
diff options
context:
space:
mode:
authorDennis Eriksen <d@ennis.no>2022-10-04 07:27:38 +0200
committerDennis Eriksen <d@ennis.no>2022-10-04 07:27:38 +0200
commit7c21bc6c6d7c43c2014d69043777ce833cf62c4c (patch)
treebf27f89c27c27db19c5f179b63d642a825804cd2 /elvia_gridtariff2pgsql.py
parentAdding doc on how to obtain api-key from entsoe (diff)
downloadenergyscripts-7c21bc6c6d7c43c2014d69043777ce833cf62c4c.tar.gz
adding grid tariff from elvia
Diffstat (limited to 'elvia_gridtariff2pgsql.py')
-rwxr-xr-xelvia_gridtariff2pgsql.py94
1 files changed, 94 insertions, 0 deletions
diff --git a/elvia_gridtariff2pgsql.py b/elvia_gridtariff2pgsql.py
new file mode 100755
index 0000000..b72f7de
--- /dev/null
+++ b/elvia_gridtariff2pgsql.py
@@ -0,0 +1,94 @@
+#!/bin/python3
+
+import os
+import sys
+import json
+import psycopg2
+import requests
+
+from datetime import datetime
+from datetime import timedelta
+from tzlocal import get_localzone
+
+
+apiKey = os.environ['elvia_grid_api_key']
+apiUrl = "https://elvia.azure-api.net/grid-tariff/digin/api/1/tariffquery/meteringpointsgridtariffs"
+meteringPointId = os.environ['meteringPointId']
+
+pg_db = os.environ['pg_db']
+pg_host = os.environ['pg_host']
+pg_table = "elvia_gridtariff"
+
+
+startTime = datetime.now(get_localzone()) - timedelta(days = 2)
+startTime = startTime.strftime('%Y-%m-%d')
+
+endTime = datetime.now(get_localzone()) + timedelta(days = 1)
+endTime = endTime.strftime('%Y-%m-%d')
+
+
+### Get the data
+try:
+ url = apiUrl
+ # Request headers
+ hdr = {
+ 'Cache-Control': 'no-cache',
+ 'X-API-Key': apiKey,
+ 'Content-Type': 'application/json'
+ }
+
+ # Request body
+ body = {
+ 'starttime': startTime,
+ 'endtime': endTime,
+ 'meteringPointIds': [ meteringPointId ]
+ }
+
+ response = requests.post(url, headers=hdr, json=body)
+ if response.status_code != 200:
+ print(response.status_code)
+ print("Oh shit")
+ response.raise_for_status()
+
+except Exception as e:
+ print("oh lol")
+ sys.exit(e)
+
+data = response.json()
+
+print("Got "+ str(len(data['gridTariffCollections'][0]['gridTariff']['tariffPrice']['hours'])) +" items from between "+ startTime + " and " + endTime)
+
+
+### insert data into database
+
+values = []
+for item in data['gridTariffCollections'][0]['gridTariff']['tariffPrice']['hours']:
+ values.append((meteringPointId, item['startTime'], item['expiredAt'], item['shortName'], item['isPublicHoliday'], item['energyPrice']['total'], item['energyPrice']['totalExVat']))
+
+# connect to database
+conn = psycopg2.connect(database=pg_db, host=pg_host)
+cur = conn.cursor()
+
+# count rows before we start
+cur.execute("SELECT COUNT(*) FROM " + pg_table)
+before = cur.fetchone()
+
+# insert data
+try:
+ cur.executemany("INSERT INTO " + pg_table + " VALUES(%s,%s,%s,%s,%s,%s,%s) ON CONFLICT (meteringPointId,startTime,endTime) DO NOTHING", values)
+ conn.commit()
+except Exception as e:
+ conn.rollback()
+ raise e
+
+# count rows after we finnish
+cur.execute("SELECT COUNT(*) FROM " + pg_table)
+after = cur.fetchone()
+
+# count *new* rows
+newRows = after[0] - before[0]
+
+# close connection
+conn.close()
+
+print("Successfully inserted " + str(newRows) + " records into the database")