-
Notifications
You must be signed in to change notification settings - Fork 1
Expand file tree
/
Copy pathGAIAfits_to_csv.py
More file actions
executable file
·53 lines (40 loc) · 1.61 KB
/
GAIAfits_to_csv.py
File metadata and controls
executable file
·53 lines (40 loc) · 1.61 KB
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
#!/usr/bin/env python
import os
import time
import datetime
import numpy as np
##################################
def main():
import csv
import numpy as np
import healpy as hp
import healpy.pixelfunc
import pandas as pd
import string,sys,os,glob
import fitsio
from glob import glob
datadir = '/data/des40.b/data/gaia/dr2/healpix'
files = glob(datadir + "/*") # a list of filenames in the datadir
done = glob('./*') # files already done and in the current directory
for f in files:
if f in done:
continue
catalog = []
healpixnum = f[f.rfind("_")+1:-5]
d = fitsio.read('/%s'%f, columns=['SOURCE_ID','RA','DEC','PHOT_G_MEAN_MAG'])
catalog.append(d)
# assumes all pixels are unique
catalog = np.concatenate(catalog)
outfile="""GaiaOut%s.csv""" % healpixnum
df=pd.DataFrame()
good_data=[]
df=pd.DataFrame(catalog.byteswap().newbyteorder(), index=range(catalog.size), columns=['SOURCE_ID','RA','DEC','PHOT_G_MEAN_MAG']) # byteswap because fits is big-endian, so swap byte order to native order
good_data.append(df)
chunk = pd.concat(good_data, ignore_index=True)
chunk = chunk.sort_values(by=['RA'], ascending=True) # DataFrame.sort is deprecated
datastd1= pd.DataFrame({'MATCHID':chunk['SOURCE_ID'],'RA':chunk['RA'],'DEC':chunk['DEC'],'WAVG_MAG_PSF':chunk['PHOT_G_MEAN_MAG']})
col=["MATCHID", "RA","DEC", "WAVG_MAG_PSF"]
datastd1.to_csv(outfile,columns=col,sep=',',index=False)
###############
if __name__ == "__main__":
main()