tiff转npy

from osgeo import gdal
import os
import numpy as np

source_dir = "C:\\Users\\Administrator\\Desktop\\SAR_specific_models-master\\data\\FUSARship-1-512-tiff"
target_dir = "C:\\Users\\Administrator\\Desktop\\SAR_specific_models-master\\data\\slc_data"

class_list = os.listdir(source_dir)
for cla in class_list:
    img_list = os.listdir(os.path.join(source_dir,cla))
    for img in img_list:
        # 拆分文件名
        name = []
        portion = os.path.splitext(img)  # 把文件名拆分为名字和后缀
        if portion[1] == ".tiff":
            name = portion[0]
            image_path = source_dir + "\\" + cla + "\\" + img
            image_name = target_dir + "\\" + cla + "\\" + name + ".npy"

            # 读取数组
            image = gdal.Open(image_path)  # 读取栅格数据
            img_array = image.ReadAsArray()

            # 创建文件夹
            if not os.path.exists(target_dir + "\\" + cla):
                os.makedirs(target_dir + "\\" + cla)

            K = np.array(img_array)
            # 存储npy文件
            np.save(image_name, K)

后续修改和补充:上面是使用gdal读取的tiff图,还可以使用cv2.imread(),也是简单方便以及常用的函数,但是要注意设置cv2.imread()的第二个参数为-1,代表不转化图像,不然cv2.imread()默认是转化为三通道rgb图像的。读取完图像后使用numpy将图像转换为数组就可了。

# 第二个参数是通道数和位深的参数,
            # IMREAD_UNCHANGED = -1  # 不进行转化,比如保存为了16位的图片,读取出来仍然为16位。
            # IMREAD_GRAYSCALE = 0  # 进行转化为灰度图,比如保存为了16位的图片,读取出来为8位,类型为CV_8UC1。
            # IMREAD_COLOR = 1   # 进行转化为RGB三通道图像,图像深度转为8位
            # IMREAD_ANYDEPTH = 2  # 保持图像深度不变,进行转化为灰度图。
            # IMREAD_ANYCOLOR = 4  # 若图像通道数小于等于3,则保持原通道数不变;若通道数大于3则只取取前三个通道。图像深度转为8位

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值