Skip to content

Command-line interface

Zarr-Python provides a command-line interface that enables:

  • migration of Zarr v2 metadata to v3
  • removal of v2 or v3 metadata

To see available commands run the following in a terminal:

zarr --help

or to get help on individual commands:

zarr migrate --help

zarr remove-metadata --help

Migrate metadata from v2 to v3

Migrate to a separate location

To migrate a Zarr array/group's metadata from v2 to v3 run:

zarr migrate v3 path/to/input.zarr path/to/output.zarr

This will write new zarr.json files to output.zarr, leaving input.zarr un-touched. Note - this will migrate the entire Zarr hierarchy, so if input.zarr contains multiple groups/arrays, new zarr.json will be made for all of them.

Migrate in-place

If you'd prefer to migrate the metadata in-place run:

zarr migrate v3 path/to/input.zarr

This will write new zarr.json files to input.zarr, leaving the existing v2 metadata un-touched.

To open the array/group using the new metadata use:

import zarr
zarr_with_v3_metadata = zarr.open('path/to/input.zarr', zarr_format=3)

Once you are happy with the conversion, you can run the following to remove the old v2 metadata:

zarr remove-metadata v2 path/to/input.zarr

Note there is also a shortcut to migrate and remove v2 metadata in one step:

zarr migrate v3 path/to/input.zarr --remove-v2-metadata

Remove metadata

Remove v2 metadata using:

zarr remove-metadata v2 path/to/input.zarr

or v3 with:

zarr remove-metadata v3 path/to/input.zarr

By default, this will only allow removal of metadata if a valid alternative exists. For example, you can't remove v2 metadata unless v3 metadata exists at that location.

To override this behaviour use --force:

zarr remove-metadata v3 path/to/input.zarr --force

Dry run

All commands provide a --dry-run option that will log changes that would be made on a real run, without creating or modifying any files.

zarr migrate v3 path/to/input.zarr --dry-run

Dry run enabled - no new files will be created or changed. Log of files that would be created on a real run:
Saving metadata to path/to/input.zarr/zarr.json

Verbose

You can also add --verbose before any command, to see a full log of its actions:

zarr --verbose migrate v3 path/to/input.zarr

zarr --verbose remove-metadata v2 path/to/input.zarr

Equivalent functions

All features of the command-line interface are also available via functions under zarr.metadata.