-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathcreate_ic.py
executable file
·81 lines (66 loc) · 3.1 KB
/
create_ic.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
from kbmod import ImageCollection
import time
import logging
import os
import glob
# Parse command line arguments
import argparse
if __name__ == '__main__':
parser = argparse.ArgumentParser(description='Converts a list of URIs to a KBMOD ImageCollection.')
# Required argument for the input file of URIs
parser.add_argument('--target_uris_file', type=str, help='The file containing the URIs of the images to be processed.')
# Required for the output file of the ImageCollection
parser.add_argument('--ic_output_file', type=str, help='The file to save the ImageCollection to.')
# Required for the output file of the ImageCollection
parser.add_argument('--uris_base_dir', type=str, help='A base directory of our target URIs, useful if the target URIs file and associated URIs have been moved between machines')
# Optional argument for debug printing
parser.add_argument('--silence', action='store_true', help="Don't print debug messages.")
args = parser.parse_args()
if args.target_uris_file is None:
print("Please provide a file containing the URIs of the images to be processed.")
exit(1)
if args.ic_output_file is None:
print("Please provide a file to save the ImageCollection to.")
exit(1)
DEBUG = True
if args.silence:
logging.basicConfig(level=logging.DEBUG)
DEBUG = False
# A function that wraps prints with a timestamp if DEBUG is True
# Accepts multiple arguments just like Python's print()
def print_debug(*msg):
if DEBUG:
print(time.strftime("%H:%M:%S", time.localtime()), *msg)
if __name__ == '__main__':
print_debug("Loading up URIs")
# Load the list of images from our saved file "sample_uris.txt"
uris = []
with open(args.target_uris_file) as f:
for l in f.readlines():
l = l.strip() # seeing invisible trailing characters 6/12/2024 COC
if l == '': continue # skip blank lines 6/12/2024 COC
if not l.startswith("#"):
# Ignore commented metadata
uris.append(l)
if args.uris_base_dir is not None:
print_debug("Using URIs base dir", args.uris_base_dir)
if not os.path.isdir(args.uris_base_dir):
raise ValueError("URIS base dir is not a valid directory", args.uris_base_dir)
# Clean up the URI strings
for i in range(len(uris)):
file_prefix = "file://"
curr = uris[i].replace('%23', '#').strip()
if curr.startswith(file_prefix):
curr = curr[len(file_prefix):]
if args.uris_base_dir is not None:
curr = os.path.join(args.uris_base_dir, curr.lstrip(os.path.sep))
uris[i] = curr
# Make sure the files can all be found 6/12/2024 COC
for uri in uris:
if len(glob.glob(uri)) == 0:
raise FileNotFoundError(f'Could not find {uri}.')
print_debug("Creating ImageCollection")
# Create an ImageCollection object from the list of URIs
ic = ImageCollection.fromTargets(uris)
print_debug("ImageCollection created")
ic.write(args.ic_output_file, format='ascii.ecsv')