Image中resize函数报错:ValueError:image has wrong mode

img_pil_u500 = np.array(img_uint500)
im_u500 = Image.fromarray(img_pil_u500) 
im_u500r = im_u500.resize((W,H),Image.ANTIALIAS)  
im_u500r.save(outputpath+str(n)+'-raw_u500pil.tif')

因为img_uint500是np.uint16的
第三句,resample的参数只能默认为Image.NEAAREST才不会报错
一旦修改就会报错:
ValueError: image has wrong mode
但是在插值中NEAREST虽然性能最好,但是效果最差
为了不丢失掉图片中的信息,最好选一个根据自己的需要选择插值算法

解决方法:
将img_uint500的数据类型转成np.uint32的话,上述代码就能运行
生成的tif图片可以直接用scipy.misc读取,得到的数据类型是int32

个人理解的原因:
The mode of an image defines the type and depth of a pixel in the image. The current release supports the following standard modes:
1 (1-bit pixels, black and white, stored with one pixel per byte)
L (8-bit pixels, black and white)
P (8-bit pixels, mapped to any other mode using a color palette)
RGB (3x8-bit pixels, true color)
RGBA (4x8-bit pixels, true color with transparency mask)
CMYK (4x8-bit pixels, color separation)
YCbCr (3x8-bit pixels, color video format)
Note that this refers to the JPEG, and not the ITU-R BT.2020, standard
LAB (3x8-bit pixels, the Lab color space)
HSV (3x8-bit pixels, Hue, Saturation, Value color space)
I (32-bit signed integer pixels)
F (32-bit floating point pixels)

Image的mode中并不支持16bit的pixels

在ECharts,`resize` 函数通常用于图表大小调整,比如当浏览器窗口大小改变时自动适应。如果你遇到 `TypeError: Cannot read properties of undefined (reading 'type')` 这样的错误,这通常是由于以下几个原因: 1. **参数未初始化**:可能是你在调用 resize 函数之前,传入的数据或某个组件还未定义或初始化。检查相关对象是否已经正确创建并且其 `.type` 属性存在。 2. **回调执行时机**:resize 是响应浏览器事件的,如果在事件处理程序引用的元素尚未加载完成,可能会导致 undefined 错误。确保在调用 resize 时,所有依赖的元素都已加载完毕。 3. **代码结构错误**:在某些情况下,可能是因为在不当的地方或者错误的时间点调用了 resize。确认 resize 是否应该在特定生命周期方法(如 `componentDidMount` 或 `window.addEventListener('resize', ...)`)内被调用。 4. **版本兼容性**:有时候,错误可能是由于使用的 ECharts 版本和当前项目需求不匹配造成的。检查你的 ECharts 版本是否是最新的,并确认该功能是否在你所使用的版本支持。 为了解决这个问题,你可以尝试按照以下步骤排查: - 检查调用 resize 函数的对象是否已经正确设置并赋值了。 - 使用 console.log 打印出可能导致错误的相关变量,看它们在执行时的状态。 - 在错误发生时添加异常处理,如 `try...catch` 来捕捉并记录错误信息。 - 如果是在 React ,确保使用法正确,比如不要在状态更新之前就尝试访问依赖数据。 如果你能提供具体的代码片段,我可以更准确地帮助分析问题。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值