forked from oceanobservatories/datateam_tools
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathcheck_ooi_nc.py
58 lines (47 loc) · 1.96 KB
/
check_ooi_nc.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
#! /usr/bin/env python
import os
import xarray as xr
import pandas as pd
import re
import fnmatch
# import click as click
from thredds_crawler.crawl import Crawl
fmt = '%Y.%m.%dT%H.%M.00'
def mk_str(attrs, str_type='t'):
"""
make a string of either 't' for title. 's' for file save name.
"""
site = attrs['subsite']
node = attrs['node']
sensor = attrs['sensor']
stream = attrs['stream']
if str_type is 's':
string = site + '-' + node + '-' + sensor + '-' + stream + '-'
else:
string = site + '-' + node + ' Stream: ' + stream + '\n' + 'Variable: '
return string
# @click.command()
# @click.argument('files', nargs=1, type=click.Path())
# @click.argument('out', nargs=1, type=click.Path(exists=False))
def main(url='http://opendap-devel.ooi.rutgers.edu:8090/thredds/catalog/first-in-class/catalog.xml', stmt='.*ncml'):
C = Crawl(url, select=[stmt])
tds = 'http://opendap-devel.ooi.rutgers.edu:8090/thredds/dodsC/'
reg_ex = re.compile('|'.join(['config', 'meta', 'engine', 'diag']))
data = []
for dataset in C.datasets:
if reg_ex.search(dataset.id) is not None:
continue
file = tds + dataset.id
with xr.open_dataset(file) as ds:
ds_disk = ds.swap_dims({'obs': 'time'}) # change dimensions from 'obs' to 'time'
# ds_variables = ds.data_vars.keys() # List of dataset variables
refdes = ds.subsite + '-' + ds.node + '-' + ds.sensor
stream = ds_disk.stream # List stream name associated with the data
delivery = ds.collection_method
start = ds.time_coverage_start
end = ds.time_coverage_end
# data.append((refdes, stream, delivery, 'Yes', 'Yes', start + ' to ' + end))
pd.DataFrame(data, columns=['RefDes','Stream','Delivery Method','Data Downloaded','Data range - MIO','Time Range'])
pd.DataFrame.to_csv('/Users/michaesm/Documents/Summary.csv')
if __name__ == '__main__':
main()