Skip to main content

Read Carl Zeiss(r) Image (CZI) files

Project description

Czifile is a Python library to read Carl Zeiss Image (CZI) files, the native file format of the ZEN(r) software by Carl Zeiss Microscopy GmbH. CZI files contain multidimensional images and metadata from microscopy experiments.

Author:Christoph Gohlke
Organization:Laboratory for Fluorescence Dynamics. University of California, Irvine
License:3-clause BSD
Version:2019.7.2

Requirements

Revisions

2019.7.2
Require tifffile 2019.7.2.
2019.6.18
Add package main function to view CZI files. Fix BGR to RGB conversion. Fix czi2tif conversion on Python 2.
2019.5.22
Fix czi2tif conversion when CZI metadata contain non-ASCII characters. Use imagecodecs_lite as a fallback for imagecodecs. Make CziFile.metadata a function (breaking). Make scipy an optional dependency; fallback on ndimage or fail on zoom().
2019.1.26
Fix czi2tif console script. Update copyright year.
2018.10.18
Rename zisraw package to czifile.
2018.8.29
Move czifile.py and related modules into zisraw package. Move usage examples to main docstring. Require imagecodecs package for decoding JpegXrFile, JpgFile, and LZW.
2018.6.18
Save CZI metadata to TIFF description in czi2tif. Fix AttributeError using max_workers=1. Make Segment.SID and DimensionEntryDV1.dimension str types. Return metadata as XML unicode string or dict, not etree. Return timestamps, focus positions, events, and luts as tuple or ndarray
2017.7.21
Use multi-threading in CziFile.asarray to decode and copy segment data. Always convert BGR to RGB. Remove bgr2rgb options. Decode JpegXR directly from byte arrays.
2017.7.13
Add function to convert CZI file to memory-mappable TIFF file.
2017.7.11
Add ‘out’ parameter to CziFile.asarray. Remove memmap option from CziFile.asarray (breaking). Change spline interpolation order to 0 (breaking). Make axes return a string. Require tifffile 2017.7.11.
2014.10.10
Read data into a memory mapped array (optional).
2013.12.4
Decode JpegXrFile and JpgFile via _czifle extension module. Attempt to reconstruct tiled mosaic images.
2013.11.20
Initial release.

Notes

The API is not stable yet and might change between revisions.

Python 2.7 and 3.4 are deprecated.

“ZEISS” and “Carl Zeiss” are registered trademarks of Carl Zeiss AG.

The ZISRAW file format design specification [1] is confidential and the license agreement does not permit to write data into CZI files.

Only a subset of the 2016 specification is implemented. Specifically, multifile images, image pyramids, and topography images are not yet supported.

Tested on Windows with a few example files only.

Czifile relies on the imagecodecs package for decoding LZW, JPEG, and JPEG XR compressed images. Alternatively, the imagecodecs_lite package can be used for decoding LZW compressed images.

Other libraries for reading CZI files (all GPL licensed):

References

  1. ZISRAW (CZI) File Format Design Specification Release Version 1.2.2. CZI 07-2016/CZI-DOC ZEN 2.3/DS_ZISRAW-FileFormat.pdf (confidential). Documentation can be requested at https://www.zeiss.com/microscopy/us/products/microscope-software/zen/czi.html

Examples

Read image data from a CZI file as numpy array:

>>> image = imread('test.czi')
>>> image.shape
(3, 3, 3, 250, 200, 3)
>>> image[0, 0, 0, 0, 0]
array([10, 10, 10], dtype=uint8)

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Files for czifile, version 2019.7.2
Filename, size File type Python version Upload date Hashes
Filename, size czifile-2019.7.2-py2.py3-none-any.whl (18.0 kB) File type Wheel Python version py2.py3 Upload date Hashes View
Filename, size czifile-2019.7.2.tar.gz (17.9 kB) File type Source Python version None Upload date Hashes View

Supported by

Pingdom Pingdom Monitoring Google Google Object Storage and Download Analytics Sentry Sentry Error logging AWS AWS Cloud computing DataDog DataDog Monitoring Fastly Fastly CDN DigiCert DigiCert EV certificate StatusPage StatusPage Status page