-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathflogger_dump_flights.py
98 lines (85 loc) · 3.68 KB
/
flogger_dump_flights.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
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
#
# This dumps the flights table to a csv file. The file name is "todays_date_time"_flights.csv
#
import settings
import string
import datetime
import time
import sqlite3
import pytz
from datetime import timedelta
import csv
#
# See http://stackoverflow.com/questions/17556450/sqlite3-python-export-from-sqlite-to-csv-text-file-does-not-exceed-20k
#
def dump_flights():
#
#-----------------------------------------------------------------
# This function converts and dumps todays' flights
# as a csv file. If there are no flight records in flights table
# it exists without creating a csv file.
#-----------------------------------------------------------------
#
print "Start flights table dump"
try:
db = sqlite3.connect(settings.FLOGGER_DB_NAME)
#Get a cursor object
cursor = db.cursor()
except:
print "Failed to connect to db"
try:
cursor.execute('''SELECT max(sdate) FROM flights''')
max_row = cursor.fetchone()
except:
print "failed to select max(sdate) FROM flights"
start_time = datetime.datetime.now()
csv_path = settings.FLOGGER_FLIGHTS_LOG + str(start_time) + "_flights.csv"
print "csv file name is: ", csv_path
if max_row <> (None,):
max_date = "".join(max_row[0:3]) #max_row[0:3] is sdate
print "Dump flights to csv. Last record date in flights is: ", max_date
# cursor.execute("SELECT * FROM flights WHERE sdate=? ORDER by sdate, stime", (max_date,))
cursor.execute("SELECT flight_no, sdate, stime, etime, duration, src_callsign, max_altitude, registration, track_file_name, tug_registration, tug_altitude, tug_model FROM flights WHERE sdate=? ORDER by sdate, stime", (max_date,))
with open(csv_path, "wb") as csv_file:
csv_writer = csv.writer(csv_file)
# Write headers.
print "Output header"
csv_writer.writerow([i[0] for i in cursor.description])
# Write data.
print "Output data"
csv_writer.writerows(cursor)
csv_file.close()
# print "End flights table dump"
# return
else:
print "No records in flights so set date to today"
today = datetime.date.today().strftime("%y/%m/%d")
max_date = datetime.datetime.strptime(today, "%y/%m/%d")
print "max_date is: ", max_date
csv_file = open(csv_path, "wb")
csv_file.truncate(0) # Zero length the file
csv_file.close()
# return
print "End flights table dump"
return csv_path
#
# This is not used and should be deleted
#
# cursor.execute("SELECT * FROM flights WHERE sdate=? ORDER by sdate, stime", (max_date,))
# cursor.execute("SELECT flight_no, sdate, stime, etime, duration, src_callsign, max_altitude, registration, track_file_name FROM flights WHERE sdate=? ORDER by sdate, stime", (max_date,))
cursor.execute("SELECT flight_no, sdate, stime, etime, duration, src_callsign, max_altitude, registration, track_file_name, tug_registration, tug_altitude, tug_model FROM flights WHERE sdate=? ORDER by sdate, stime", (max_date,))
start_time = datetime.datetime.now()
csv_path = settings.FLOGGER_FLIGHTS_LOG + str(start_time) + "_flights.csv"
print "csv file name is: ", csv_path
with open(csv_path, "wb") as csv_file:
csv_writer = csv.writer(csv_file)
# Write headers.
print "Output header"
csv_writer.writerow([i[0] for i in cursor.description])
# Write data.
print "Output data"
csv_writer.writerows(cursor)
csv_file.close()
print "End flights table dump"
return
#dump_flights()