-
Notifications
You must be signed in to change notification settings - Fork 7
/
Copy pathglider_sensor_calsheets.py
111 lines (90 loc) · 3.94 KB
/
glider_sensor_calsheets.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
99
100
101
102
103
104
105
106
107
108
109
110
111
#!/usr/bin/env python
"""
Created on Feb 1 2018
@author: [email protected]
@brief: This script is used to convert spreadsheets provided by the MIOs to calibration sheets for glider CTDs and
DOSTAs that include sensor calibration dates. Cal sheets to be added to asset management:
https://github.com/ooi-integration/asset-management
"""
import pandas as pd
import netCDF4 as nc
import os
import datetime
def convert_osu_file(file, sheet_names):
for s in sheet_names:
name = str(s)
print '\nConverting sheet name: %s' %name
f = pd.read_excel(file, sheetname=name, skiprows=1)
for i,j in f.iterrows():
ctd_sn = int(j['SN'])
ctd_uid = 'CGINS-CTDGVM-' + '{0:05d}'.format(ctd_sn)
print ctd_uid
ctd_inst = 'CTDGVM'
ctd_caldate_str = str(j['Cal Date'])[0:10].replace('-','')
ctd_caldate_num = int(nc.date2num(j['Cal Date'],'seconds since 1970-01-01'))*1000
ctd_sdir = os.path.join(dir,ctd_inst)
create_dir(ctd_sdir)
write_csv(ctd_uid, ctd_caldate_str, ctd_caldate_num, ctd_sn, ctd_sdir)
do_sn = int(j['SN.3'])
do_uid = 'CGINS-DOSTAM-' + '{0:05d}'.format(do_sn)
print do_uid
do_inst = 'DOSTAM'
do_caldate_str = str(j['Cal Date.3'])[0:10].replace('-','')
do_caldate_num = int(nc.date2num(j['Cal Date.3'],'seconds since 1970-01-01'))*1000
do_sdir = os.path.join(dir,do_inst)
create_dir(do_sdir)
write_csv(do_uid, do_caldate_str, do_caldate_num, do_sn, do_sdir)
def convert_whoi_file(file, sheet_names):
for s in sheet_names:
name = str(s)
print '\nConverting sheet name: %s' %name
c = {col: str for col in (1, 3)} # read in the date columns as strings instead of floats
f = pd.read_excel(file, sheetname=name, converters=c)
for i,j in f.iterrows():
uid = j['Sensor_UID']
print uid
sn = int(uid.split('-')[-1])
inst = uid.split('-')[1]
caldate1_str = j['Cal_Date_1']
caldate1_num = int(nc.date2num(datetime.datetime.strptime(caldate1_str,'%Y%m%d'),'seconds since 1970-01-01'))*1000
sdir = os.path.join(dir,inst)
create_dir(sdir)
write_csv(uid, caldate1_str, caldate1_num, sn, sdir)
caldate2_str = (j['Cal_Date_2'])
if pd.isnull(caldate2_str):
continue
else:
caldate2_num = int(nc.date2num(datetime.datetime.strptime(caldate2_str,'%Y%m%d'),'seconds since 1970-01-01'))*1000
write_csv(uid, caldate2_str, caldate2_num, sn, sdir)
def create_dir(new_dir):
# Check if dir exists.. if it doesn't... create it.
if not os.path.isdir(new_dir):
try:
os.makedirs(new_dir)
except OSError:
if os.path.exists(new_dir):
pass
else:
raise
def get_sheetnames(file):
xls = pd.ExcelFile(file)
sheet_names = xls.sheet_names
return sheet_names
def write_csv(uid, caldate_str, caldate_num, sn, sdir):
cols = ['serial','name','value','notes']
fname = uid + '__' + caldate_str + '.csv'
df = pd.DataFrame([[sn,'CC_calibration_date',caldate_num,'sensor calibration date (milliseconds since 1970-01-01)']], columns = cols)
df.to_csv(os.path.join(sdir,fname),index=False)
def main(dir, input_files):
for ifile in input_files:
print '\nConverting file: %s' %ifile
file = os.path.join(dir,ifile)
sheet_names = get_sheetnames(file)
if ifile == 'ScienceConfigs.xlsx':
convert_osu_file(file, sheet_names)
else:
convert_whoi_file(file, sheet_names)
if __name__ == '__main__':
dir = '/Users/lgarzio/Documents/OOI/glider_calsheets'
input_files = ['Coastal Pioneer Glider Sensor Cals.xlsx','Global Glider Sensor Cals.xlsx','ScienceConfigs.xlsx']
main(dir, input_files)