-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathparse_obsid_hlsp_k2sc.py
79 lines (63 loc) · 2.77 KB
/
parse_obsid_hlsp_k2sc.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
"""
.. module:: parse_obsid_hlsp_k2sc
:synopsis: Given a K2SC obsID returns the corresponding K2 target ID,
file name, cadence type, campaign, etc.
.. moduleauthor:: Scott W. Fleming <fleming@stsci.edu>
"""
import collections
import os
import re
#--------------------
def parse_obsid_hlsp_k2sc(obsid):
"""
Given a K2SC observation ID, returns the file to read.
:param obsid: The K2SC observation ID to retrieve the data from.
:type obsid: str
:returns: tuple -- An error code and a list of the set of files to read
(including paths).
Error codes:
0 = No error parsing observation ID.
1 = Error parsing K2SC observation ID.
2 = Cadence not recognized as long cadence.
3 = File is missing on disk.
"""
# Create namedtuple as the return object.
parsed_values = collections.namedtuple('ParseResult', ['k2scid',
'cadence',
'campaign',
'errcode', 'files'])
# Initialize error code to 0 = pass.
error_code = 0
# This string defines the version, used in both the path and file names.
ver_str = 'v2'
# Split the observation ID into K2SC star name, campaign, and cadence.
try:
k2scid, campaign, cadence = [
x for x in re.split('k2sc|_|-', obsid) if x != '']
except ValueError:
error_code = 1
return parsed_values(k2scid='', cadence='', campaign='',
errcode=error_code, files=[''])
# Make sure the cadence type is 'lc'.
if cadence != 'lc':
error_code = 2
return parsed_values(k2scid=k2scid, cadence=cadence,
campaign=campaign, errcode=error_code, files=[''])
# Use the observation ID to get paths to each file.
dir_root = (os.path.pardir + os.path.sep + os.path.pardir + os.path.sep +
"hlsps" + os.path.sep + "k2sc" +
os.path.sep + ver_str + os.path.sep + campaign + os.path.sep)
star_dir_root = (k2scid[0:4] + "00000" + os.path.sep)
# Generate FITS file name based on observation ID.
file_name = ("hlsp_k2sc_k2_llc_"+ k2scid +
"-" + campaign + "_kepler_"+ver_str+"_lc.fits")
full_file_name = dir_root + star_dir_root + file_name
if os.path.isfile(full_file_name):
return parsed_values(k2scid=k2scid, cadence=cadence,
campaign=campaign, errcode=error_code,
files=[full_file_name])
error_code = 3
return parsed_values(k2scid=k2scid, cadence=cadence,
campaign=campaign, errcode=error_code,
files=[full_file_name])
#--------------------