toposhirt/get_ee_from_region.py
2026-01-28 09:38:45 -08:00

144 lines
3.7 KiB
Python
Executable File

#!/usr/bin/env python3
''' This is a template for creating new python scripts,
complete with argument processing and simple I/O '''
import logging
import stat
import os
import sys
import argparse
import time
class Timerlog:
def __init__(self, name):
self.time_start = 0.0
self.time_end = 0.0
self.name = name
def start(self):
self.time_start = time.perf_counter()
return self
def end(self):
self.time_end = time.perf_counter()
return self
def report(self, duration_only=False):
if duration_only:
return "Timer [{}] duration [{:.5f}]".format(
self.name, self.time_end - self.time_start)
return "Timer [{}] begin [{:.5f}] end [{:.5f}] duration [{:.5f}]".format(
self.name, self.time_start, self.time_end, self.time_end - self.time_start)
program_name = 'get_ee_from_region.py'
parser = argparse.ArgumentParser(
prog=program_name,
description='get a url from google ee api based on supplied region',
epilog='Good luck')
group = parser.add_mutually_exclusive_group()
parser.add_argument(
"-l",
"--logging",
dest='logging',
metavar='log_file',
required=False,
action='store',
help="log to file")
parser.add_argument(
"-v",
"--verbose",
dest='verbose',
required=False,
action='store_true',
help="verbose mode, log output goes to stderr")
parser.add_argument(
"-c",
"--country",
dest='country',
metavar='country',
default='United States',
action='store',
help="country to get topo image for")
parser.add_argument(
"-r",
"--region",
dest='region',
metavar='region',
dest='region',
metavar='region',
default='None',
action='store',
help="subregion to get, default is to get entire country")
args = parser.parse_args()
if args.logging or args.verbose:
handlers = []
if args.logging:
file_handler = logging.FileHandler(filename=args.logging)
handlers.append(file_handler)
if args.verbose:
stderr_handler = logging.StreamHandler(stream=sys.stderr)
handlers.append(stderr_handler)
logging.basicConfig(
encoding='utf-8',
handlers=handlers,
format='%(asctime)s.%(msecs)03d %(levelname)s {%(module)s} [%(funcName)s] %(message)s',
datefmt='%Y-%m-%d,%H:%M:%S',
level=logging.DEBUG)
if args.logging:
logging.debug('logging to log_file requested')
if args.verbose:
logging.debug('logging to stderr requested')
if args.dump:
print(open(sys.argv[0]).read())
exit(0)
if args.filename:
with open(args.filename, "w") as fd:
fd.write(open(sys.argv[0]).read())
mode = os.fstat(fd.fileno()).st_mode
mode |= stat.S_IXUSR | stat.S_IXGRP | stat.S_IXOTH
os.fchmod(fd.fileno(), stat.S_IMODE(mode))
exit(0)
if args.binary:
args.utf8 = False
input_file = sys.stdin.buffer
if args.input_file != 'stdin':
input_file = open(args.input_file, "rb")
output_file = sys.stdout.buffer
if args.output_file != 'stdout':
output_file = open(args.output_file, "wb")
output_file.write(input_file.read())
exit(0)
if args.utf8:
input_file = sys.stdin
if args.input_file != 'stdin':
input_file = open(args.input_file, "r")
output_file = sys.stdout
if args.output_file != 'stdout':
output_file = open(args.output_file, "w")
try:
output_file.write(input_file.read())
except UnicodeDecodeError as e:
print("Error: input data is not Unicode.\nTry again with the -b option to force binary mode",
file=sys.stderr)
exit(1)
exit(0)