-
Notifications
You must be signed in to change notification settings - Fork 47
/
Copy pathtimespan.py
58 lines (49 loc) · 2.15 KB
/
timespan.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
import os
import csv
from datetime import datetime
from park_api import db, env
def timespan(city, lot_id, total, date_from, date_to, version):
now = datetime.utcnow().strftime("%Y-%m-%dT%H:%M:%S")
if date_from > now or version == 1.0:
data = forecast(lot_id, total, date_from, date_to, version)
elif date_to < now:
data = known_timespan_data(city, lot_id, date_from, date_to, version)
else:
data = known_timespan_data(city, lot_id, date_from, now, version)
data.extend(forecast(lot_id, total, now, date_to, version))
return data
def known_timespan_data(city, lot_id, date_from, date_to, version):
if version == 1:
return {}
elif version == "1.1":
with db.cursor() as cur:
sql = '''SELECT timestamp_downloaded, data \
FROM parkapi \
WHERE timestamp_downloaded > %s AND timestamp_downloaded < %s AND city = %s'''
cur.execute(sql, (date_from, date_to, city,))
data = []
for row in cur.fetchall():
for lot in row['data']['lots']:
if lot['id'] == lot_id:
data.append({"timestamp": row["timestamp_downloaded"].strftime("%Y-%m-%dT%H:%M:%S"),
"free": lot["free"]})
return data
def forecast(lot_id, total, date_from, date_to, version):
if version == 1.0:
try:
csv_path = os.path.join(env.APP_ROOT, "forecast_data", lot_id + ".csv")
with open(csv_path) as csvfile:
data = {}
for row in csv.reader(csvfile):
if date_from <= row[0] <= date_to:
data[row[0]] = row[1]
return data
except FileNotFoundError:
return {}
elif version == "1.1":
try:
csv_path = os.path.join(env.APP_ROOT, "forecast_data", lot_id + ".csv")
with open(csv_path) as csvfile:
return [{"timestamp": row[0], "free": int(total * (1 - int(row[1]) / 100))} for row in csv.reader(csvfile) if date_from <= row[0] <= date_to]
except FileNotFoundError:
return []