-
Notifications
You must be signed in to change notification settings - Fork 7
/
Copy pathdatawire.py
38 lines (31 loc) · 1.02 KB
/
datawire.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
import sqlaload as sl
import time
from datastringer import DataStringer
from common import *
from dump import generate_all
log = logging.getLogger('dump')
def submit_all():
engine = db_connect()
spending = sl.get_table(engine, 'spending')
stringer = DataStringer(service='ukspending',
event='transactions')
log.info("Submitting frames to datawire...")
failures = 0
for i, row in enumerate(generate_all()):
action_at = row.get('DateFormatted')
if action_at:
action_at = datetime.datetime.strptime(action_at, '%Y-%m-%d')
try:
stringer.submit(row,
action_at=action_at,
source_url=row.get('SourceURL'))
failures = 0
except Exception, e:
failures += 1
if failures > 10:
raise e
time.sleep(5)
data = {'datawire_submitted': True}
sl.update(engine, spending, row)
if __name__ == '__main__':
submit_all()