python读取hdf文件

使用netCDF4库可读取hdf4或hdf5数据

import netCDF4 as nc

f = nc.Dataset('1.hdf')
vars = f.variables
for var in vars:
    print(var) #查看变量
data = f['Optical_Depth_047'][:]  #即可获取数据

介绍其他库分别读取hdf4和hdf5格式

  1. 读取hdf4格式
from pyhdf.SD import SD
f = SD('1.hdf')
print (f)
print(f.info())
data_dic = f.datasets()
for idx,sds in enumerate(data_dic.keys()):
	print (idx,sds)
od01 = f.select('Optical_Depth_047')[:]
#或
od02 = f.select('Optical_Depth_047').get()
  1. 读取hdf5格式

参考网址

import h5py  #导入工具包
import numpy as np
#HDF5的写入:
imgData = np.zeros((30,3,128,256))
f = h5py.File('HDF5_FILE.h5','w')   #创建一个h5文件,文件指针是f
f['data'] = imgData                 #将数据写入文件的主键data下面
f['labels'] = range(100)            #将数据写入文件的主键labels下面
f.close()                           #关闭文件
 
#HDF5的读取:
f = h5py.File('HDF5_FILE.h5','r')   #打开h5文件
f.keys()                            #可以查看所有的主键
a = f['data'][:]                    #取出主键为data的所有的键值
f.close()

如果变量里面没有经纬度,那可通过查看属性获知经纬度范围和步长,从而自己构造出二维经纬度格点。

  • 5
    点赞
  • 23
    收藏
    觉得还不错? 一键收藏
  • 3
    评论
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值