aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rwxr-xr-xastro/query_ned.py39
1 files changed, 15 insertions, 24 deletions
diff --git a/astro/query_ned.py b/astro/query_ned.py
index 30791fd..4af11e5 100755
--- a/astro/query_ned.py
+++ b/astro/query_ned.py
@@ -1,22 +1,12 @@
#!/usr/bin/env python3
#
-# Copyright (c) 2016-2017 Weitian LI <liweitianux@live.com>
-# MIT license
+# Copyright (c) 2016-2018 Weitian LI <weitian@aaronly.me>
+# MIT License
#
# References:
# [1] astroquery: NedClass
# https://astroquery.readthedocs.org/en/latest/api/astroquery.ned.NedClass.html
#
-# Change log:
-# 2017-02-11:
-# * Add argument "--brief" to not print header
-# 2016-05-25:
-# * Also output RA, DEC results
-# * Update argument process
-# * Simplify queried results process
-# * Improve comments a bit
-# * Some PEP8 fixes
-#
# TODO:
# * allow to query by coordinates & radius range
# * filter queried results according to the type/other...
@@ -35,15 +25,13 @@ from collections import OrderedDict
from astroquery.ned import Ned
from astroquery.exceptions import RemoteServiceError
-# from astropy import coordinates
-# import astropy.units as u
# Ned configurations
Ned.TIMEOUT = 20
-def query_name(name, verbose=False):
+def query_name(name, verbose=False, print_header=False):
"""
Query NED by source name.
"""
@@ -58,12 +46,7 @@ def query_name(name, verbose=False):
z_flag = q["Redshift Flag"][0].decode("utf-8")
refs = q["References"][0]
notes = q["Notes"][0]
- if verbose:
- print("%s: %s,%s,%s,%s,%s,%s,%s,%s,%s" %
- (name, objname, objtype, ra, dec, velocity, z, z_flag,
- refs, notes),
- file=sys.stderr)
- except RemoteServiceError as e:
+ except RemoteServiceError:
objname = None
objtype = None
ra = None
@@ -88,6 +71,10 @@ def query_name(name, verbose=False):
("References", refs),
("Notes", notes),
])
+ if verbose:
+ if print_header:
+ print(",".join(results.keys()))
+ print(",".join([str(v) for v in results.values()]))
return results
@@ -102,8 +89,9 @@ def main():
help="be brief and do not print header")
parser.add_argument("-i", "--input", dest="input", required=True,
help="source names to be queried (sep by comma); " +
- "or a file contains the names (one per line)")
- parser.add_argument("-o", "--output", dest="output", default=sys.stdout,
+ "or a file contains the names (one per line)")
+ parser.add_argument("-o", "--output", dest="output",
+ default=sys.stdout,
help="output CSV file with queried data")
args = parser.parse_args()
@@ -114,8 +102,11 @@ def main():
results_list = []
+ print_header = True
for name in names:
- qr = query_name(name, verbose=args.verbose)
+ qr = query_name(name, verbose=args.verbose,
+ print_header=print_header)
+ print_header = False
results_list.append(qr)
try: