PIL 从 I;16 转换为 JPEG 产生白色图像

PIL converting from I;16 to JPEG produce white image

我在使用 PIL 将图像 I;16 转换为 JPEG 时遇到问题。 我的原始图像可以找到here(作为pickle)。 原始图像来自 DICOM 文件。 这是尝试的代码:

import pickle
import matplotlib.pyplot as plt
from PIL import Image

ims = pickle.load(open("pixel_array.pickle", "rb"))

img = Image.fromarray(ims)
print(img.mode)
rgb_im = img.convert("RGB")
print(rgb_im.mode)

fig, ax = plt.subplots(figsize=(20, 10))
ax.imshow(rgb_im, cmap=plt.cm.bone)
fig.show()

遗憾的是图像是全白的,而它应该是胸部 X 光扫描图像。

我关注了 其他 Whosebug 问题,并提出了以下问题

ims = pickle.load(open("pixel_array.pickle", "rb"))

img = Image.fromarray(ims)
print(img.mode)

img.mode = 'I'
rgb_im = img.point(lambda i:i*(1./256)).convert('L')
rgb_im.save('my.jpeg')

fig, ax = plt.subplots(figsize=(20, 10))
ax.imshow(rgb_im, cmap=plt.cm.bone)
fig.show()

我可以看到图像,但不幸的是 my.jpeg 是黑色图像。请帮忙!

您的值是 16 位的,需要缩减为 8 位才能显示。您可以使用以下方法将它们从当前范围 2,712(即 ims.min())扩展到 4,328(即 ims.max()):

from PIL import Image
import numpy as np
import pickle

# Load image
ims = pickle.load(open("pixel_array.pickle", "rb"))

# Normalise to range 0..255
norm = (ims.astype(np.float)-ims.min())*255.0 / (ims.max()-ims.min())

# Save as 8-bit PNG
Image.fromarray(norm.astype(np.uint8)).save('result.png')