Source code for unravel.image_io.img_to_npy
#!/usr/bin/env python3
"""
Use ``io_img_to_npy`` from UNRAVEL to convert a 3D image to an ndarray and save it as a .npy file.
Usage:
------
io_img_to_npy -i path/to/image.czi -o path/to/image.npy [-ao zyx] [-v]
"""
import numpy as np
from rich.traceback import install
from unravel.core.help_formatter import RichArgumentParser, SuppressMetavar, SM
from unravel.core.config import Configuration
from unravel.core.img_io import load_3D_img
from unravel.core.utils import log_command, verbose_start_msg, verbose_end_msg
[docs]
def parse_args():
parser = RichArgumentParser(formatter_class=SuppressMetavar, add_help=False, docstring=__doc__)
reqs = parser.add_argument_group('Required arguments')
reqs.add_argument('-i', '--input', required=True, help='Input image file path (.czi, .nii.gz, .tif)', action=SM)
reqs.add_argument('-o', '--output', required=True, help='Output HDF5 file path', action=SM)
opts = parser.add_argument_group('Optional args')
opts.add_argument('-ao', '--axis_order', help='Axis order for the image (default: zyx)', default='zyx', action=SM)
general = parser.add_argument_group('General arguments')
general.add_argument('-v', '--verbose', help='Increase verbosity. Default: False', action='store_true', default=False)
return parser.parse_args()
[docs]
@log_command
def main():
install()
args = parse_args()
Configuration.verbose = args.verbose
verbose_start_msg()
img = load_3D_img(args.input, desired_axis_order=args.axis_order)
if args.output:
output = args.output
elif args.input.endswith('.czi'):
output = args.input.replace('.czi', '.npy')
elif args.input.endswith('.nii.gz'):
output = args.input.replace('.nii.gz', '.npy')
elif args.input.endswith('.tif'):
output = args.input.replace('.tif', '.npy')
elif args.input.endswith('.zarr'):
output = args.input.replace('.zarr', '.npy')
# Save the ndarray to a binary file in NumPy `.npy` format
np.save(output, img)
verbose_end_msg()
if __name__ == '__main__':
main()