Image readers and writers for image2image.
Project description
image2image-io
Overview
This library provides reader/writer interface to several popular image formats. The main goal is to give a unified interface to access the image data (e.g. for specific channel or pyramid level).
Getting started
Currently supported formats:
- Standard image formats (.png, .jpg, .jpeg)
- TIFF (.tif, .tiff, .ome.tiff, .scn, .svs, .ndpi, .qptiff, .qptiff.raw, .qptiff.intermediate)
- CZI (.czi)
- Bruker (.tsf, .tdf, .d)
- ImzML (.imzML, .ibd)
- HDF5 (.h5, .hdf5) - specific schema required
- Numpy (.npy, .npz) - expects 2D or 3D numpy array
- GeoJSON (.geojson) - expects a dictionary with 'type' and 'features' keys (e.g. from QuPath or GeoPandas)
- Points (.csv, .txt, .parquet) - specific schema required
If you want to open an image, you can use the get_simple_reader function. This function will automatically detect the
image format and return the appropriate reader.
from image2image_io.readers import get_simple_reader
# Path to your image
path_to_image = "path/to/image.ome.tiff"
# Get instance of the reader.
reader = get_simple_reader(
path_to_image,
init_pyramid=True # initialize the pyramid upon loading the image
)
# Retrieve the pyramid stack. In this case 'pyramid' is a list of numpy or dask arrays.
pyramid = reader.pyramid
# Retrieve the first channel of the first pyramid level
channel_first = reader.get_channel(0, 0) # channel_id, pyramid_level
# Retrieve the first channel of the last pyramid level
channel_last = reader.get_channel(0, -1) # channel_id, pyramid_level
# Writing to file is relatively easy
reader.to_ome_tiff(
'path/to/output.ome.tiff',
as_uint8=True, # will convert the data to uint8
tile_size=1024, # tile size for the output image
channel_ids=[0, 2], # channel ids - specify which channels to write
channel_names=['Channel 1', 'Channel 3'], # channel names - specify the names of the channels
)
Writing a numpy array to an OME-TIFF file is also possible:
import numpy as np
from image2image_io.writers import write_ome_tiff_from_array
# Create a numpy array
array = np.random.randint(0, 255, (100, 100, 3), dtype=np.uint8) # RGB image
# Write the numpy array to an OME-TIFF file
write_ome_tiff_from_array(
"path/to/output.ome.tiff",
None,
array,
tile_size=1024, # tile size for the output image
channel_names=["R", "G", "B"], # for RGB images, this might now have any effect
resolution=0.5, # resolution of the image in microns
)
Merging multiple images is alsy fairly easy to do:
from image2image_io.writers import merge_images
# Paths to the images
paths = ["path/to/image1.ome.tiff", "path/to/image2.ome.tiff"]
# Merge the images
merge_images(
"output.ome.tiff", # filename
paths, # list of paths to the images
output_dir="path/to/output/dir", # output directory for the final image
tile_size=1024, # tile size for the output image
metadata={ # metadata for the output image - this specifies which channels to use in the export
"path/to/image1.ome.tiff": {
0: {
"name": "image-1",
"channel_ids": [0, 2],
"channel_names": ["Channel 1", "Channel 3"],
}
},
"path/to/image2.ome.tiff": {
0: {
"name": "image-2",
"channel_ids": [0, 1],
"channel_names": ["Channel 1", "Channel 2"],
}
}
}
)
Command-line interface
A command-line interface (CLI) is provided to perform common tasks without writing code. You can access the CLI using the
image2image-io command after installing the package.
❯ i2io --help
Usage: i2io [OPTIONS] COMMAND [ARGS]...
Convert, merge, and manipulate image files.
Options:
--dev Flat to indicate that CLI should run in development mode and catch all errors.
--no_color Flag to enable colored while doing tasks.
--version Show the version and exit.
-v, --verbose Verbose output. This is additive flag so `-vvv` will print `INFO` messages and -vvvv will print
`DEBUG` information.
-q, --quiet Minimal output
--debug Maximum output
-h, --help Show this message and exit.
OME-TIFF:
convert Convert images to pyramidal OME-TIFF.
merge Export images.
CZI:
cziinfo Print information about the CZI file.
czi2tiff Convert CZI to OME-TIFF.
Utility:
thumbnail Create a thumbnail for image(s).
transform Transform command.
For instance, the i2io convert command let's you convert between a few file formats (e.g. CZI to OME-TIFF) or create
a different representation of the image, for instance with different tiling or data type.
Contributing
Contributions are always welcome. Please feel free to submit PRs with new features, bug fixes, or documentation improvements.
git clone https://github.com/vandeplaslab/image2image-io.git
pip install -e .[dev]
Project details
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file image2image_io-0.3.0.tar.gz.
File metadata
- Download URL: image2image_io-0.3.0.tar.gz
- Upload date:
- Size: 3.8 MB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.14.3
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
3f641b16c93a6d8f977e330303e4810d190b5bdf4bfe803faf17f8212cc861b1
|
|
| MD5 |
598cb15ce4b52bfc6eeacf2d3446fe8f
|
|
| BLAKE2b-256 |
f011c49365f900276baafa9e03beadae9b486cc23c3ea5af96b6bdd23a5575ef
|
File details
Details for the file image2image_io-0.3.0-py3-none-any.whl.
File metadata
- Download URL: image2image_io-0.3.0-py3-none-any.whl
- Upload date:
- Size: 109.1 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.14.3
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
9259ccdaef4318386cb586d5205e1d9e8c0ac26999b6ece11986bda332380dd2
|
|
| MD5 |
a684b8dee78eee8174b265a1760b71e5
|
|
| BLAKE2b-256 |
6616f11854e4e14db3e90b3d234b5f8e1ffb38892548765f4f087a4020f49462
|