forked from opengeos/NASA-Earth-Data
-
Notifications
You must be signed in to change notification settings - Fork 0
/
nasa_earth_data.py
115 lines (96 loc) · 3.24 KB
/
nasa_earth_data.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
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
import json
import earthaccess
import pandas as pd
earthaccess.login()
datasets = earthaccess.search_datasets(keyword="*")
def get_info(dataset):
info = {}
info["ShortName"] = dataset["umm"]["ShortName"]
info["EntryTitle"] = dataset["umm"]["EntryTitle"]
try:
info["DOI"] = dataset["umm"]["DOI"]["DOI"]
except:
info["DOI"] = ""
info["concept-id"] = dataset["meta"]["concept-id"]
info["provider-id"] = dataset["meta"]["provider-id"]
try:
info["s3-links"] = dataset["meta"]["s3-links"]
except:
info["s3-links"] = ""
# info["granule-count"] = dataset["meta"]["granule-count"]
try:
bbox_crs = dataset["umm"]["SpatialExtent"]["HorizontalSpatialDomain"][
"Geometry"
]["CoordinateSystem"]
coords = dataset["umm"]["SpatialExtent"]["HorizontalSpatialDomain"]["Geometry"][
"BoundingRectangles"
][0]
bbox = [
coords["WestBoundingCoordinate"],
coords["SouthBoundingCoordinate"],
coords["EastBoundingCoordinate"],
coords["NorthBoundingCoordinate"],
]
info["bbox-crs"] = bbox_crs
info["bbox"] = bbox
except:
info["bbox-crs"] = ""
info["bbox"] = ""
try:
grid_res = dataset["umm"]["SpatialExtent"]["HorizontalSpatialDomain"][
"ResolutionAndCoordinateSystem"
]["HorizontalDataResolution"]
if "GriddedResolutions" in grid_res:
horizontal_res = grid_res["GriddedResolutions"]
elif "GenericResolutions" in grid_res:
horizontal_res = grid_res["GenericResolutions"]
else:
horizontal_res = ""
info["horizontal_res"] = horizontal_res
except:
info["horizontal_res"] = ""
try:
start_time = dataset["umm"]["TemporalExtents"][0]["RangeDateTimes"][0][
"BeginningDateTime"
]
info["start-time"] = start_time
except:
info["start-time"] = ""
try:
end_time = dataset["umm"]["TemporalExtents"][0]["RangeDateTimes"][0][
"EndingDateTime"
]
info["end-time"] = end_time
except:
info["end-time"] = ""
try:
info["Creator"] = dataset["umm"]["CollectionCitations"][0]["Creator"]
except:
info["Creator"] = ""
try:
info["Publisher"] = dataset["umm"]["CollectionCitations"][0]["Publisher"]
except:
info["Publisher"] = ""
try:
info["ReleaseDate"] = dataset["umm"]["CollectionCitations"][0]["ReleaseDate"]
except:
info["ReleaseDate"] = ""
try:
info["ReleasePlace"] = dataset["umm"]["CollectionCitations"][0]["ReleasePlace"]
except:
info["ReleasePlace"] = ""
try:
info["Version"] = dataset["umm"]["CollectionCitations"][0]["Version"]
except:
info["Version"] = ""
if info["DOI"] != "":
info["Linkage"] = "https://doi.org/" + info["DOI"]
else:
info["Linkage"] = ""
return info
data = [get_info(dataset) for dataset in datasets]
df = pd.DataFrame(data)
df.sort_values(by=["ShortName"], inplace=True)
df.to_csv("nasa_earth_data.tsv", index=False, sep="\t")
with open("nasa_earth_data.json", "w") as f:
json.dump(df.to_dict("records"), f, indent=4)