-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathngmdb.py
83 lines (76 loc) · 2.68 KB
/
ngmdb.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
# https://ngmdb.usgs.gov/ngm-bin/ngm_search_json.pl?State=CA&Counties=Contra%20Costa&Counties=Alameda
import argparse
import re
import requests
from rich.console import Console
from rich.table import Table
from rich.highlighter import RegexHighlighter
from rich.theme import Theme
SEARCH_ENDPOINT = "https://ngmdb.usgs.gov/ngm-bin/ngm_search_json.pl"
STATE_CODES = [
"AK", "AL", "AR", "AS", "AZ", "CA", "CO", "CT", "DC", "DE", "FL", "GA", "GU",
"HI", "IA", "ID", "IL", "IN", "KS", "KY", "LA", "MA", "MD", "ME", "MI", "MN",
"MO", "MP", "MS", "MT", "NC", "ND", "NE", "NH", "NJ", "NM", "NV", "NY", "OH",
"OK", "OR", "PA", "PR", "RI", "SC", "SD", "TN", "TX", "UT", "VA", "VI", "VT",
"WA", "WI", "WV", "WY"
]
class GeologicMapHighlighter(RegexHighlighter):
"""Highlight text relative to geologic maps"""
base_style = "underfoot."
highlights = [
re.compile(r"(?P<geologic>geologic|geology)", re.IGNORECASE),
re.compile(r"(?P<geologic_map>geologic map)", re.IGNORECASE),
re.compile(r"(?P<database>database)", re.IGNORECASE)
]
theme = Theme({
"underfoot.geologic_map": "bold green",
"underfoot.geologic": "green",
"underfoot.database": "bold yellow"
})
if __name__ == "__main__":
parser = argparse.ArgumentParser(description="Search NGMDB for geologic sources")
parser.add_argument(
"--state",
type=str,
choices=STATE_CODES,
help="US state (two-letter)"
)
parser.add_argument(
"--counties",
type=str,
action="append"
)
args = parser.parse_args()
print(f"args: {args}")
response = requests.get(SEARCH_ENDPOINT, {
"State": args.state,
"Counties": args.counties,
"format": "gis"
})
# headers = ["title", "scale", "year", "url"]
# data = [[
# result["title"],
# result["scale"],
# result["year"],
# f"https://ngmdb.usgs.gov/Prodesc/proddesc_{result['id']}.htm",
# ] ]
# table = PrettyTable()
# table.field_names = headers
# table.align["title"] = "l"
# table.align["url"] = "l"
# table.add_rows(data)
# print(table)
table = Table(title="NGMDB Results", highlight=True)
table.add_column("title")
table.add_column("scale", justify="right")
table.add_column("year", justify="right")
table.add_column("url")
for result in response.json()["ngmdb_catalog_search"]["results"]:
table.add_row(
result["title"],
result["scale"],
str(result["year"]),
f"https://ngmdb.usgs.gov/Prodesc/proddesc_{result['id']}.htm"
)
console = Console(highlighter=GeologicMapHighlighter(), theme=theme)
console.print(table)