-
Notifications
You must be signed in to change notification settings - Fork 2
/
run.py
executable file
·82 lines (73 loc) · 2.93 KB
/
run.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
#!/usr/bin/python
"""
Top level script. Calls other functions that generate datasets that this script then creates in HDX.
"""
import argparse
import logging
from os import environ
from os.path import join
from geoboundaries import generate_dataset, get_data
from hdx.api.configuration import Configuration
from hdx.facades.simple import facade
from hdx.utilities.downloader import Download
from hdx.utilities.path import progress_storing_tempdir
logger = logging.getLogger(__name__)
lookup = "hdx-ext-scraper-geoboundaries"
def main():
"""Generate dataset and create it in HDX"""
configuration = Configuration.read()
with Download() as downloader:
admin_boundaries = get_data(downloader, configuration["url"])
countries = [{"iso3": x} for x in sorted(admin_boundaries)]
logger.info(f"Number of countries to upload: {len(countries)}")
for info, country in progress_storing_tempdir(lookup, countries, "iso3"):
countryiso3 = country["iso3"]
country_admin_boundaries = admin_boundaries[countryiso3]
boundarytypes, dataset, resource_names = generate_dataset(
countryiso3, country_admin_boundaries
)
if dataset:
dataset.update_from_yaml()
dataset[
"notes"
] = f"This dataset contains the following administrative boundaries: {', '.join(boundarytypes)}. \n \n{dataset['notes']}"
dataset.create_in_hdx(
remove_additional_resources=True,
hxl_update=False,
updated_by_script="GeoBoundaries",
batch=info["batch"],
)
existing_order = [x["name"] for x in dataset.get_resources()]
if existing_order != resource_names:
sorted_resources = sorted(
dataset.get_resources(),
key=lambda x: resource_names.index(x["name"]),
)
dataset.reorder_resources(
[x["id"] for x in sorted_resources], hxl_update=False
)
if __name__ == "__main__":
parser = argparse.ArgumentParser(description=lookup)
parser.add_argument("-hk", "--hdx_key", default=None, help="HDX api key")
parser.add_argument("-hs", "--hdx_site", default=None, help="HDX site to use")
parser.add_argument(
"-s",
"--start",
default="RESET",
help="ISO3 to start. Defaults to starting from beginning.",
)
args = parser.parse_args()
hdx_site = args.hdx_site
if hdx_site is None:
hdx_site = "stage"
start = args.start
if start != "RESET":
start = f"iso3={start}"
environ["WHERETOSTART"] = start
facade(
main,
hdx_key=args.hdx_key,
hdx_site=hdx_site,
user_agent=lookup,
project_config_yaml=join("config", "project_configuration.yml"),
)