python处理葵花8 netCDF4(nc格式)数据

前言

本文主要是处理葵花8(Himawari 8) L1级netCDF格式数据
葵花8(Himawari 8)卫星数据请自行百度教程,官网数据下载地址:https://www.eorc.jaxa.jp/ptree/registration_top.html

数据简介:https://www.eorc.jaxa.jp/ptree/userguide.html

所需要的库:

netCDF4
gdal

代码

import numpy as np
import netCDF4 as nc
from osgeo import gdal, osr, ogr
import os

data = r"...\dataset\H8\NC_H08_20160902_1050_R21_FLDK.06001_06001.nc"
nc_data = nc.Dataset(data)  # 读入数据
print(nc_data)

输出结果如下,可以看到头文件信息,包括行列号、数据时间、范围和网格大小(空间分辨率)

<class 'netCDF4._netCDF4.Dataset'>
root group (NETCDF4 data model, file format HDF5):
    title: Himawari-8 AHI equal latitude-longitude map data
    id: NC_H08_20160902_1050_R21_FLDK.06001_06001.nc
    date_created: 2016-09-02T11:05:56Z
    pixel_number: 6001
    line_number: 6001
    upper_left_latitude: 60.0
    upper_left_longitude: 80.0
    grid_interval: 0.02
    band_number: 16
    dimensions(sizes): latitude(6001), longitude(6001), band(16), time(1), geometry(17)
    variables(dimensions): float32 latitude(latitude), float32 longitude(longitude), int32 band_id(band), float64 start_time(time), float64 end_time(time), float64 geometry_parameters(geometry), int16 albedo_01(latitude, longitude), int16 albedo_02(latitude, longitude), int16 albedo_03(latitude, longitude), int16 sd_albedo_03(latitude, longitude), int16 albedo_04(latitude, longitude), int16 albedo_05(latitude, longitude), int16 albedo_06(latitude, longitude), int16 tbb_07(latitude, longitude), int16 tbb_08(latitude, longitude), int16 tbb_09(latitude, longitude), int16 tbb_10(latitude, longitude), int16 tbb_11(latitude, longitude), int16 tbb_12(latitude, longitude), int16 tbb_13(latitude, longitude), int16 tbb_14(latitude, longitude), int16 tbb_15(latitude, longitude), int16 tbb_16(latitude, longitude), int16 SAZ(latitude, longitude), int16 SAA(latitude, longitude), int16 SOZ(latitude, longitude), int16 SOA(latitude, longitude), int16 Hour(latitude, longitude)
    groups: 
list(nc_data.variables.keys())

这样可以清晰的看到数据集中包含哪些数据,可以把nc数据看成是一个大的字典,可以按keys来提取数据。

['latitude',
 'longitude',
 'band_id',
 'start_time',
 'end_time',
 'geometry_parameters',
 'albedo_01',
 'albedo_02',
 'albedo_03',
 'sd_albedo_03',
 'albedo_04',
 'albedo_05',
 'albedo_06',
 'tbb_07',
 'tbb_08',
 'tbb_09',
 'tbb_10',
 'tbb_11',
 'tbb_12',
 'tbb_13',
 'tbb_14',
 'tbb_15',
 'tbb_16',
 'SAZ',
 'SAA',
 'SOZ',
 'SOA',
 'Hour']
# 查看温度波段的头文件信息,可以看到名称、比例因子、偏移量、单位等信息。
nc_data['tbb_13']
<class 'netCDF4._netCDF4.Variable'>
int16 tbb_13(latitude, longitude)
    long_name: Brightness temperature of band 13
    units: K
    valid_min: -27315
    valid_max: 32767
    scale_factor: 0.01
    add_offset: 273.15
    missing_value: -32768
unlimited dimensions: 
current shape = (6001, 6001)
filling on, default _FillValue of -32767 used

提取12波段的亮温数据

tbb_12 = np.asarray(nc_data['tbb_12'][:])  # 结果为物理量

nc原数据是一个整数,这里netCDF4直接进行了计算,将其转为了亮温的开尔文物理量。

lat = nc_data['latitude'][:]
lon = nc_data['longitude'][:]
latMin, latMax, lonMin, lonMax = lat.min(), lat.max(), lon.min(), lon.max()
# 分辨率
lat_Res = (latMax - latMin) / (lat.shape[0]-1)
lon_Res = (lonMax - lonMin) / (lon.shape[0]-1)

# 保存路径和名称,先占个坑
driver = gdal.GetDriverByName('GTiff')
out_tif_name = r'...\dataset\H8\H8_20160902_tbb_12_temp.tif'
out_tif = driver.Create(out_tif_name, lon.shape[0], lat.shape[0], 1, gdal.GDT_Float32)

# 输出结果
geotransform = (lonMin,lon_Res, 0, latMax, 0, -lat_Res)
out_tif.SetGeoTransform(geotransform)
srs = osr.SpatialReference()
srs.SetWellKnownGeogCS('WGS84')
out_tif.SetProjection(srs.ExportToWkt())
out_tif.GetRasterBand(1).WriteArray(tbb_12)
out_tif.FlushCache()
out_tif = None
  • 5
    点赞
  • 39
    收藏
    觉得还不错? 一键收藏
  • 27
    评论
### 回答1: Python中可以使用netcdf4库来读取nc数据。具体步骤如下: 1. 安装netcdf4库 可以使用pip命令来安装netcdf4库,命令如下: ``` pip install netcdf4 ``` 2. 导入netcdf4库 在Python代码中导入netcdf4库,命令如下: ``` import netCDF4 ``` 3. 打开nc文件 使用netCDF4库中的Dataset函数打开nc文件,命令如下: ``` nc = netCDF4.Dataset('filename.nc', 'r') ``` 其中,'filename.nc'为nc文件的路径,'r'表示以只读方式打开文件。 4. 读取nc数据 可以使用nc.variables函数来读取nc文件中的变量,命令如下: ``` var = nc.variables['variable_name'] ``` 其中,'variable_name'为nc文件中的变量名。 5. 关闭nc文件 使用nc.close()函数关闭nc文件,命令如下: ``` nc.close() ``` 以上就是使用Python netcdf4库读取nc数据的基本步骤。 ### 回答2: Python是一种非常流行的编程语言,适用于许多数据分析和科学计算任务。NetCDF4是一种用于存储科学数据的文件格式,并提供了一套非常灵活的API,可以轻松地读写NetCDF文件。本文将介绍如何使用Python NetCDF4库读取NetCDF格式数据NetCDF是Network Common Data Form的缩写,是一种自描述性的二进制数据格式,主要用于科学数据的存储和交换。对于大型、复杂数据集,NetCDF是一种很好的选择,因为它可以存储多维数据、元数据处理历史记录。NetCDF文件具有自描述性,因为文件中包含有关数据和元数据的详细信息,包括数据维度、变量和属性。NetCDF文件还可以跨平台使用,因此在不同操作系统之间传输数据将更容易。 Python NetCDF4库是Python的一个扩展库,用于读取NetCDF格式数据。几乎所有NetCDF文件都可以使用这个库来读取。 下面是使用Python NetCDF4库读取NetCDF格式数据的详细步骤: 1.导入NetCDF4库: 首先,我们需要将Python NetCDF4库导入我们的程序中。我们可以使用以下代码完成此操作: import netCDF4 as nc 2.打开NetCDF文件: 我们需要打开NetCDF格式的文件,以便可以访问其中的数据。我们可以使用以下代码打开一个NetCDF文件: data = nc.Dataset('filename.nc') ‘filename.nc’是要打开的文件名,它应该是一个NetCDF格式的文件。 3.检查NetCDF文件的内容: 我们可以使用以下代码打印NetCDF文件中存储的变量和其尺寸: for var in data.variables: print(var, data.variables[var].dimensions) 这将显示NetCDF文件中所有变量的名称和它们的维数。 4.访问NetCDF变量: 我们可以使用以下代码访问NetCDF文件中的变量: variable = data.variables['variable_name'] ‘variable_name’是要访问的变量名称。 5.读取NetCDF变量的值: 我们可以使用以下代码读取NetCDF变量的所有值: data_array = variable[:] 6.关闭NetCDF文件: 在读取完NetCDF文件中的数据后,我们应该将其关闭,以便释放内存资源。我们可以使用以下代码完成此操作: data.close() 上述代码是使用Python NetCDF4库读取NetCDF格式数据的基本步骤。 总的来说, python netcdf4是一种非常强大的工具,可用于处理天气、气候、海洋和地球物理科学数据等领域。它提供了许多函数和方法,可用于读取、写入和操作NetCDF格式数据。通过了解以上步骤,您可以轻松地使用Python NetCDF4库读取并处理NetCDF格式数据。 ### 回答3: NetCDF文件是一种常用的气象、海洋和地球物理场数据存储格式PythonNetCDF4库提供了读取和处理NetCDF数据的功能。 使用NetCDF4库,首先需要导入该库: ``` import netCDF4 ``` 接着,可以使用`netcdf4.Dataset`函数打开NetCDF文件并创建`Dataset`对象: ``` ncfile = netCDF4.Dataset('filename.nc', 'r') ``` 其中,`filename.nc`是要读取的NetCDF文件名,`'r'`表示以只读模式打开文件。 使用`Dataset`对象,可以读取NetCDF文件中的变量、维度和属性等信息。例如,可以使用`variables`属性获取文件中的变量信息: ``` varnames = ncfile.variables.keys() for varname in varnames: var = ncfile.variables[varname] print(varname, var.dtype, var.dimensions, var.shape) ``` 此外,还可以使用`dimensions`属性获取文件中的维度信息: ``` dimnames = ncfile.dimensions.keys() for dimname in dimnames: dim = ncfile.dimensions[dimname] print(dimname, len(dim)) ``` 其中,`len(dim)`表示该维度的长度。 对于变量的具体数值,可以使用`[:]`或`getValue()`方法进行读取。例如,可以读取名为`temperature`的变量: ``` temperature = ncfile.variables['temperature'][:] # 或者 temperature = ncfile.variables['temperature'].getValue() ``` 此时,`temperature`变量即为NetCDF文件中名为`temperature`的变量的数值数组。 除此之外,NetCDF文件还可以包含一些属性。可以使用`attrs`属性获取属性信息: ``` attrnames = ncfile.ncattrs() for attrname in attrnames: attr = ncfile.getncattr(attrname) print(attrname, attr) ``` 其中,`ncattrs()`方法可以获取所有属性的名称,`getncattr(attrname)`方法可以获取指定属性的值。 最后,记得关闭NetCDF文件: ``` ncfile.close() ``` 本文介绍了使用PythonNetCDF4库读取NetCDF数据的基本方法,包括打开文件、获取变量、维度和属性信息、读取变量数值以及关闭文件等。这些方法可以帮助用户方便地进行数据抽取、处理和分析等操作。
评论 27
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值