This warning:Lossy conversion from float64 to uint8. Range [0, 1].

在图像预处理/图片处理的过程中,会带有把uint8图像转换成float64类型的警告提示:Lossy conversion from float64 to uint8. Range [0, 1]. Convert image to uint8 prior to saving to suppress this warning.
在这里插入图片描述
这时只要添加一行代码即可:

dst = (dst*255.0).astype('uint8')

整体代码如下:


from skimage import io, transform, color
import numpy as np
def convert_gray(f, **args):  # 图片处理与格式化的函数
    rgb = io.imread(f)  # 读取图片
    gray = color.rgb2gray(rgb)  # 将彩色图片转换为灰度图片
    dst = transform.resize(gray, output_shape=(1024, 1024)) # 调整大小,图像分辨率的大小
    dst = (dst*255.0).astype('uint8')  #保存为uint8类型
    return dst
datapath = '/Users/yym/Desktop/n/'  # 图片所在的路径
str = datapath + '/*.jpg'  # 识别.jpg的图像
coll = io.ImageCollection(str, load_func=convert_gray) # 批处理
for i in range(len(coll)):
    io.imsave(r'/Users/yym/Desktop/ui/' + np.str(i) + '.jpg', coll[i])# 保存图片在
  • 6
    点赞
  • 15
    收藏
    觉得还不错? 一键收藏
  • 3
    评论
### 回答1: 这是一个关于数据类型转换的警告,它提示你将浮点数转换为无符号整数8位会导致数据丢失,因为浮点数的数值范围在[0, 1],而无符号整数8位的范围是[0, 255]。为了避免这种警告,请在保存前将图像转换为无符号整数8位。 ### 回答2: 在Python中,我们通常使用NumPy库来处理图像,其中包括将图像从浮点数(float64)转换为无符号8位整数(uint8)。但是,在这个过程中,我们可能会遇到一个警告,即“lossy conversion from float64 to uint8. range [0,1]. convert image to uint8 prior to saving to suppress this warning.”(从float64到uint8的精度损失。范围[0,1]。在保存之前将图像转换为uint8以压制此警告。) 这个警告的意思是说,在这个过程中,有可能出现数据的精度损失,因为uint8只能表示整数值范围在0到255之间,而float64则可以表示更广泛的范围。因此,在将图像转换为uint8之前,最好从预处理的阶段开始,尽量保持数据的精度。 为了解决这个警告,我们可以使用NumPy中的astype()函数将图像从float64转换为uint8类型。我们需要将图像的值限制在0到1之间,以确保它们适合于uint8类型。实现方式如下: img = img.astype(np.float32) / 255.0 img = (img * 255).astype(np.uint8) 首先,我们将图像按0到1的范围进行归一化,将其转换为float32类型。然后,我们将图像乘以255,将其值从0到1扩展到0到255,并将其转换为uint8类型。使用这种方法,我们可以避免在从float64到uint8的转换过程中出现精度损失。 最后,将转换后的图像保存为图像文件时,不会再出现警告:“lossy conversion from float64 to uint8. range [0, 1]. convert image to uint8 prior to saving to suppress this warning.”(从float64到uint8的精度损失。范围[0,1]。在保存之前将图像转换为uint8以压制此警告。) ### 回答3: 这是一条关于Python编程语言中的警告信息。该警告信息提示用户,在将一个float64类型的数据转换成uint8类型的数据时,可能会出现某些数据丢失的情况。同时,建议在将图像保存时,先将它转换成uint8类型的数据,以避免该警告。 在Python语言中,float64是一种浮点数类型,其范围为-1到1之间。而uint8是一种8位整数类型,取值范围为0到255之间。这意味着,在将一个float64类型的数据转换成uint8类型的数据时,可能会出现数据精度的损失。例如,如果某个float64类型的数据的值为0.8,它在转换成uint8类型的数据后,可能会变成1或2,这就导致了数据的丢失。 为了避免这种情况的发生,警告信息建议在将图像保存之前,将其转换成uint8类型的数据。这样做的目的是将图像数据的精度限制在0到255之间,保证图像数据不会在转换时发生丢失。具体来说,可以使用该编程语言中的“astype”函数将图像转换成uint8类型的数据。 总之,这条警告信息提醒我们在编写Python程序时需要注意数据类型的转换和精度问题。在进行数据类型转换时,建议对数据的精度进行评估,以避免数据在转换时出现丢失。同时,在保存数据时,建议先将其转换成正确的类型再进行保存,以保证数据的完整性。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值