diff options
author | Dennis Eriksen <d@ennis.no> | 2023-11-09 14:11:35 +0100 |
---|---|---|
committer | Dennis Eriksen <d@ennis.no> | 2023-11-09 14:11:35 +0100 |
commit | e8e33997b360bfee461d5939b7c9fef5f3de6e8c (patch) | |
tree | 8f61e55c69edbd6abf140aba462bf535c83e1f22 /scripts/entsoe.py | |
parent | added new function to get env (diff) | |
download | energyscripts-e8e33997b360bfee461d5939b7c9fef5f3de6e8c.tar.gz |
optimize and simplify
- use more fstrings
- use exceptions
- don't print "oh lol"
- drop tempfiles
Diffstat (limited to 'scripts/entsoe.py')
-rw-r--r-- | scripts/entsoe.py | 40 |
1 files changed, 19 insertions, 21 deletions
diff --git a/scripts/entsoe.py b/scripts/entsoe.py index 2c825c2..1836229 100644 --- a/scripts/entsoe.py +++ b/scripts/entsoe.py @@ -24,7 +24,7 @@ from tzlocal import get_localzone apiKey = common.env("el_entsoe_token") # https://transparency.entsoe.eu/content/static_content/Static%20content/web%20api/Guide.html -apiUrl = "https://web-api.tp.entsoe.eu/api?securityToken=" + apiKey +apiUrl = "https://web-api.tp.entsoe.eu/api" startTime = datetime.now(get_localzone()) - timedelta(days=7) startTime = startTime.strftime("%Y%m%d") @@ -33,8 +33,6 @@ startTime = startTime.strftime("%Y%m%d") endTime = datetime.now(get_localzone()) + timedelta(days=1) endTime = endTime.strftime("%Y%m%d") -jobname = os.path.splitext(os.path.basename(__file__))[0] - # https://transparency.entsoe.eu/content/static_content/Static%20content/web%20api/Guide.html#_areas areas = [ {"name": "NO-0", "code": "10YNO-0--------C"}, @@ -47,34 +45,34 @@ areas = [ UTC = tz.gettz("UTC") CET = tz.gettz("Europe/Oslo") +# Create a session object for making requests +session = requests.Session() # Get the data values = [] for area in areas: try: url = ( - apiUrl - + "&documentType=A44&in_Domain=" - + area["code"] - + "&out_Domain=" - + area["code"] - + "&periodStart=" - + startTime - + "0000&periodEnd=" - + endTime - + "0000" + f"{apiUrl}" + f"?securityToken={apiKey}" + f"&documentType=A44" + f"&in_Domain={area['code']}" + f"&out_Domain={area['code']}" + f"&periodStart={startTime}0000" + f"&periodEnd={endTime}0000" ) print("Getting data for " + area["code"]) - response = requests.get(url, timeout=10) - if response.status_code != 200: - print(response.status_code) - print("Oh shit") - response.raise_for_status() + + # Use the session object to make the request + response = session.get(url, timeout=10) + + # Handle any exceptions or non-200 status code + response.raise_for_status() except requests.exceptions.RequestException as e: - print("oh lol") - sys.exit(e) + print(f"Error: {e}") + sys.exit(1) data_dict = xmltodict.parse(response.content) @@ -95,7 +93,7 @@ for area in areas: # append values values.append((time, area["name"], item["price.amount"])) - print("Got " + str(items) + " records") + print(f"Got {items} records") # SQL sql = """ INSERT INTO entsoe |