当我尝试以与切片Numpy数组完全相同的方式切片Zarr数组时,为什么会出现此错误



我正在使用以下代码从磁盘切片Zarr阵列:

import zarr as zr
db = zr.open('/content/drive/My Drive/Share/Daily Data/Database/dbz.zarr', mode='r')
data = db[db[:,0]==20171003]

错误如下:

IndexError                                Traceback (most recent call last)
<ipython-input-16-4ae364a8c3b1> in <module>()
1 dbz_ranked = zr.open('/content/drive/My Drive/Share/Daily Data/Database/dbz_ranked.zarr', mode='w', shape=(8245164, 345),chunks=(100000, 345), dtype='float64')
----> 2   data = db[db[:,0]==20171003]

3 frames
/usr/local/lib/python3.6/dist-packages/zarr/indexing.py in __init__(self, selection, array)
280                 raise IndexError('unsupported selection item for basic indexing; '
281                                  'expected integer or slice, got {!r}'
--> 282                                  .format(type(dim_sel)))
283 
284             dim_indexers.append(dim_indexer)
IndexError: unsupported selection item for basic indexing; expected integer or slice, got <class 'numpy.ndarray'>

我不知道为什么这不起作用,我以为Zarr应该像Numpy数组一样切片?

我发现以下页面很有用:https://zarr.readthedocs.io/en/stable/api/core.html

总之,使用zarr_array.oindex([])可以实现经典的索引/切片。

最新更新