-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathbuild-kerchunk-fsspec-working-caringo-in-quobyte-out.py
51 lines (38 loc) · 1.85 KB
/
build-kerchunk-fsspec-working-caringo-in-quobyte-out.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
"""Build a Kerchunk zip file without touching the disk"""
import os
import json
import kerchunk.hdf
import fsspec
from urllib.parse import urlparse
DEFAULT_BUCKET_NAME = "s3-acclim"
#kerchunk-test/CMIP6/CMIP/MOHC/HadGEM3-GC31-MM/1pctCO2/r1i1p1f3/Amon/hus/gn/v20200115/
urls = ["http://cmip6-zarr-o.s3.jc.rl.ac.uk/A-NC-CMIP6.CMIP.MOHC.HadGEM3-GC31-MM/" + f for f in [
"1pctCO2.r1i1p1f3.Amon.hus.gn.v20200115.185001-186912.nc"]]
#urls = ["s3://s3.sds.jc.rl.ac.uk/s3-acclim/kerchunk-test/CMIP6/CMIP/MOHC/HadGEM3-GC31-MM/1pctCO2/r1i1p1f3/Amon/hus/gn/v20200115/hus_Amon_HadGEM3-GC31-MM_1pctCO2_r1i1p1f3_gn_185001-186912.nc"]
# read the access key and secret key from a json file in the directory
with open(os.path.expanduser("./config.json.quobyte")) as fh:
config = json.load(fh)
# construct the input options for fsspec
fssopts = {
"key": config["accessKey"],
"secret": config["secretKey"],
"client_kwargs": {"endpoint_url": config["url"]}
}
for u in urls:
# munge the url name to get the output object path and add .json
url_parts = urlparse(u)
url_parts = url_parts._replace(path=url_parts.path+".json")
#import pdb; pdb.set_trace()
bucket_name = url_parts.path.split("/")[1]
bucket_name = DEFAULT_BUCKET_NAME
object_name = url_parts.path.split("/")[2]
# construct the output url and connect to output fsspec
url_out = f"s3://{bucket_name}/{object_name}"
# with fsspec.open(u, "rb", **fssopts) as infss:
with fsspec.open(u) as infss:
print(f"Working on: {u}")
# generate kerchunk and write to buffer
h5chunks = kerchunk.hdf.SingleHdf5ToZarr(infss, u, inline_threshold=100)
with fsspec.open(url_out, "wb", **fssopts) as out_fss:
out_fss.write(json.dumps(h5chunks.translate()).encode())
print(f"Written file: {bucket_name}/{object_name}")