当我保存图像时,它的格式是numpy.uint16,当我加载它时,它是numpy.uint8,它为我弄乱了整个流水线。如何防止这种情况发生?
我在打电话
from scipy.misc import imread, imsave
image = imread(path)
imread(image_path)发布于 2018-08-13 13:41:25
imsave和imread方法已弃用,并将在未来的SciPy版本中删除。改用imageio.imwrite和imageio.imread应该可以解决这个问题。
>>> import imageio
>>> img = imageio.imread('img.jpg')
>>> img.dtype
dtype('uint8')
>>> imageio.imwrite('img_saved.jpg', img)
>>> img_read = imageio.imread('img_saved.jpg')
>>> img_read.dtype
dtype('uint8')发布于 2018-08-14 00:43:06
我将16位灰度数据写入TIFF和从TIFF读取,如下所示:
#!/usr/local/bin/python3
import numpy as np
from PIL import Image
# Make a greyscale image of random 16-bit ints in range 0..65535
arr = np.random.randint(0,65535,(320,240), dtype=np.uint16)
# Make PIL image from numpy array and save
im=Image.fromarray(arr).save("result.tif")
# Re-read from file
reloadedim = Image.open("result.tif")
reloadedarr = np.array(reloadedim)
# Calculate difference
diff = arr - reloadedarr
print("Number of different pixels: {}".format(sum(diff.ravel())))它打印“不同像素数: 0”。
https://stackoverflow.com/questions/51815361
复制相似问题