-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathd1.py
77 lines (69 loc) · 2.59 KB
/
d1.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
#!/usr/bin/env python3
from cloudflare import Cloudflare, APIConnectionError, RateLimitError, APIStatusError
from pathlib import Path
from json import load
import os
if not os.environ.get("CF_API_TOKEN") or not os.environ.get("CF_ACCOUNT_ID") or not os.environ.get("CF_DATABASE_ID"):
print("missing enviroment variables")
exit(1)
client = Cloudflare(
api_token=os.environ.get("CF_API_TOKEN")
)
def load_json(file):
f = open(file, encoding="utf8")
return load(f)
station_path = (
Path(__file__)
.parent.absolute()
.joinpath("./out/json/brands/stations_ARAL Tankstelle_min.json")
)
def export_stations():
station_data = load_json(station_path)
tmp_lists = []
tmp_list = []
counter = 0
for station in station_data:
# FIXME: the should be a better way for this
tmp_list.append("INSERT INTO stations (id,name,lat,lng,address,city,state,postcode,"
"country_code,telephone,site_brand,watchlist_id,website,fuel,facilities) "
"VALUES ({},\"{}\",{},{},\"{}\",\"{}\",\"{}\",{},\"{}\",\"{}\",\"{}\",{},\"{}\",\"{}\",\"{}\");".format(station["watchlist_id"],
station["name"],
station["lat"],
station["lng"],
station["address"],
station["city"],
station["state"],
station["postcode"],
station["country_code"],
station["telephone"],
station["site_brand"],
station["watchlist_id"],
station["website"],
", ".join(station["products"]),
", ".join(station["facilities"])))
counter = counter + 1
if len(tmp_list) > 98:
tmp_lists.append(tmp_list)
tmp_list = []
counter = 0
querys = ["DELETE FROM stations;"]
tmp_query = []
for entry in tmp_lists:
for station in entry:
tmp_query.append(station)
querys.append("".join(tmp_query))
tmp_query = []
for query in querys:
try:
client.d1.database.query(account_id=os.environ.get("CF_ACCOUNT_ID"), database_id=os.environ.get("CF_DATABASE_ID"), sql=query)
except APIConnectionError as e:
print("The server could not be reached")
print(e.__cause__) # an underlying Exception, likely raised within httpx.
except RateLimitError as e:
print("A 429 status code was received; we should back off a bit.")
except APIStatusError as e:
print("Another non-200-range status code was received")
print(e.status_code)
print(e.response)
if __name__ == "__main__":
export_stations()