Python 读取hdf数据

 以Modis数据为例,要读取其中'Cloud_Phase_Infrared'变量

from pyhdf.SD import SD

def readModis(filename):
    ds = SD(filename)
    attributes = ds.select('Cloud_Phase_Infrared').attributes()##'Cloud_Phase_Infrared'变量的属性
    scales = attributes['scale_factor']#乘积缩放系数  在'Cloud_Phase_Infrared'是1
    offset = attributes['add_offset']#加法缩放系数  在'Cloud_Phase_Infrared'是0
    cloud_phase = ds.select('Cloud_Phase_Infrared')[:]#(406,270)
    # 127: 缺测      0: 晴空(cloud free)      1: 水云(water cloud)       2:冰云(ice cloud)      3:混合云(mixed phase cloud)       6:不确定相态 (undetermined phase)
    cloud_phase=cloud_phase.astype('float32')#原来类型是int8 数据只能在-128 - 127之间 改成float32好处理
    cloud_phase = cloud_phase * scales + offset
    cloud_phase[cloud_phase==127]=-999
    lon = ds.select('Longitude')[:]#(406,270)
    lat = ds.select('Latitude')[:]#(406,270)

    return cloud_phase,lon,lat

if __name__=="__main__":
    raw_phase_modis,raw_lon_modis,raw_lat_modis=readModis('/MOD06_L2.A2016063.0200.061.2017325162309.hdf')#(406,270)

另外,想查看hdf变量信息使用:

ds.info(),以我这个数据为例,输出是(127,14) 其中127是127个变量  14是属性.info(): get the number of datasets stored in the file and the number of attributes attached to it

打印数据中变量名:

for idx, sds in enumerate(ds.datasets().keys()):#ds.datasets().keys() 变量名称
    print(idx, sds)


 

  • 0
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值