代码分享-NC多时相数据利用Matlab代码提取

本文详细描述了如何使用Matlab脚本处理NC文件中的SPEI数据,通过循环读取、替换NaN值、旋转数据以及创建地理参考信息,最终将子集数据保存为tif格式的地理空间文件。
摘要由CSDN通过智能技术生成

NC多时相数据利用Matlab代码提取

ncFileBasePath = ‘’; % nc 文件的基础路径
tiffOutFileBasePath = ‘’; % tif 文件的输出路径
kenyaLatlim = [-4 4];
kenyaLonlim = [33 42];
% 获取 nc 文件列表>> % 获取 nc 文件列表
ncFiles = dir(fullfile(ncFileBasePath, ‘*.nc’));
% 循环处理每个 nc 文件
for fileIndex = 1:length(ncFiles)
% 完整文件名
filename = ncFiles(fileIndex).name;
% 不带后缀的文件名
filenameWithoutSuffix = filename(1:find(filename == ‘.’) - 1);
% nc 文件的完整路径
fileFullPath = fullfile(ncFileBasePath, filename);
% 读取 SPEI 数据
ETaSets = ncread(fileFullPath, ‘spei’);
% 获取数据集的大小信息
sizeInfo = size(ETaSets);% 循环处理每个子集
for subsetIndex = 1:sizeInfo(3)% 获取单个子集数据
MonthData = ETaSets(:, :, subsetIndex);% 将 NaN 值替换为特定值
MonthData(isnan(MonthData)) = -8888;% 创建 tif 文件的输出路径和文件名
tifOutputFullPath = fullfile(tiffOutFileBasePath, …
[filenameWithoutSuffix, sprintf(‘%02d’, subsetIndex), ‘.tif’]);% 对数据进行处理和转换
MonthData = rot90(MonthData); % 旋转数据
Refference = georasterref(‘RasterSize’, size(MonthData), …
‘Latlim’, kenyaLatlim, ‘Lonlim’, kenyaLonlim); % 创建参考信息
Refference.ColumnsStartFrom = ‘north’; % 指定列的起始位置
geotiffwrite(tifOutputFullPath, MonthData, Refference); % 写入为 geotiff 文件
end
end

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

jr428

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值