-
Notifications
You must be signed in to change notification settings - Fork 3
/
podi_getinfo.py
executable file
·91 lines (74 loc) · 2.64 KB
/
podi_getinfo.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
#!/usr/bin/env python3
#
# Copyright 2012-2013 Ralf Kotulla
#
# This file is part of the ODI QuickReduce pipeline package.
#
# If you find this program or parts thereof please make sure to
# cite it appropriately (please contact the author for the most
# up-to-date reference to use). Also if you find any problems
# or have suggestiosn on how to improve the code or its
# functionality please let me know. Comments and questions are
# always welcome.
#
# The code is made publicly available. Feel free to share the link
# with whoever might be interested. However, I do ask you to not
# publish additional copies on your own website or other sources.
#
# This program is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
#
"""
Create a night-log for a given list of input frame.
This log lists, for each frame
* filename
* type of observation: bias/dark/flat/science
* binning
* filter name
* exposure time
* Object/target name as specified during the observation (this is not necessarily
the real name of the target, rather what the user entered)
* pointing coordinates: Ra/Dec
The output of this file is compatible with the file-list requirements of, for
example, podi_makecalibrations.
"""
import sys
import os
import astropy.io.fits as pyfits
from podi_definitions import get_binning
if __name__ == "__main__":
for filename in sys.argv[1:]:
if (not os.path.isfile(filename)):
continue
try:
hdulist = pyfits.open(filename)
hdr = hdulist[0].header
except:
continue
obstype, object, exptime, filter, dateobs, expmeas = "???", "???", -999, "???", "???", -1
try:
obstype = hdr['OBSTYPE']
object = hdr['OBJECT']
exptime = hdr['EXPTIME']
filter = hdr['FILTER']
dateobs = hdr['DATE-OBS']
binning = get_binning(hdulist[1].header)
expmeas = hdr['EXPMEAS'] if 'EXPMEAS' in hdr else -1.
except:
pass
ra = hdr['RA']
dec = hdr['DEC']
print("%(filename)s %(dateobs)s %(obstype)6s %(binning)d %(filter)15s %(exptime)8.3f %(expmeas)8.3f %(object)60s %(ra)14s %(dec)14s" % {
"filename": filename,
"dateobs": dateobs,
"obstype": obstype,
"binning": binning,
"filter": filter,
"exptime": exptime,
"expmeas": expmeas,
"object": object,
"ra": ra,
"dec": dec
})