From 8d186d39483beff64a1c11f80c6ca5e56dd7bbc5 Mon Sep 17 00:00:00 2001 From: Dennis Eriksen Date: Wed, 1 Feb 2023 20:32:11 +0100 Subject: moving and renaming/breaking everything --- tibber_consumption2pgsql.py | 102 -------------------------------------------- 1 file changed, 102 deletions(-) delete mode 100755 tibber_consumption2pgsql.py (limited to 'tibber_consumption2pgsql.py') diff --git a/tibber_consumption2pgsql.py b/tibber_consumption2pgsql.py deleted file mode 100755 index e710b8f..0000000 --- a/tibber_consumption2pgsql.py +++ /dev/null @@ -1,102 +0,0 @@ -#!/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 - - -# variables -apiKey = os.environ['el_tibber_token'] -apiUrl = "https://api.tibber.com/v1-beta/gql" - -pg_db = os.environ['el_pg_db'] -pg_host = os.environ['el_pg_host'] -pg_table = "tibber_consumption" - -startTime = datetime.now(get_localzone()) - timedelta(days = 1) -startTime = startTime.isoformat('T') - -endTime = datetime.now(get_localzone()).isoformat('T') - -# Get the data -try: - url = apiUrl - - # Request headers - hdr = { - 'Authorization': "Bearer " + apiKey, - 'Content-Type': 'application/json', - } - - body = {"query":"""{ - viewer { - homes { - consumption(resolution: HOURLY, last:100) { - nodes { - from - to - cost - unitPrice - unitPriceVAT - consumption - consumptionUnit - } - } - } - } }"""} - - 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() - -numdata = len(data["data"]["viewer"]["homes"][0]["consumption"]["nodes"]) -print("Got " + str(numdata) + " rows from Tibber") - -### insert data into database -# consumption -values = [] -for item in data["data"]["viewer"]["homes"][0]["consumption"]["nodes"]: - if item["consumption"] is not None: - values.append((item["from"],item["to"],item["consumption"],item["consumptionUnit"],item["cost"],item["unitPrice"],item["unitPriceVAT"])) - -# connect to db -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 (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") -- cgit v1.2.3